ASP開發 如何提高WEB程式的效率

2021-04-01 02:16:43 字數 3433 閱讀 5957

很多網友非常不喜歡用asp來程式設計,他們總是抱怨說asp程式太慢,效率太低。更希望用php,jsp等來寫程式。其實不能從 "認為" 這個角度來看問題 ,而應該從實際中看問題,asp真的很慢的嗎,那麼微軟的站為何用asp也不慢呢?php真的很快嗎,其實它也仍然是解釋性的語言。只不過在linux下的結合比較好而以。jsp的開發也不會簡單到何處,而且要通過jdbc-odbc橋才能連線access庫等,這種情況下效率也不高。

其實,三種語言各有特點,就是優,缺點。作為乙個程式設計師不應該總是怪語言不好,而更應該看重的是自己的技術。所以今天我們不會比較這三種web語言到底誰好,誰壞,而是講解如何提高程式的執行效率問題。

第一篇:sql語句篇

web程式中最引人注目的應該是資料庫操作。今天我們就來講講如何提高sql語句的效率。假設有一張結構如下的users的**,其中id為主鍵。已經有10000條記錄。

id int 4 自增

name char 10 //姓名

age int 2 //年齡

*** char 2 //性別 預設值為 "男"

address nvchar 255 //位址

cash int 4 //積分

photo char 2 //是否有** 預設值為 "沒有"

photourl nvchar 255 //**路徑

首頁我們講講關於資料庫中表和字段的問題,對於web進行的資料庫物件中,自然表的個數越少,越好;表中的安段個數越少,越好;欄位中所佔的位元組是越少,越好。

例如users表中***的字段完全可以用bit欄位,進行0或1的操作,可以定義 "0"為男性,而 "1"為女性,這樣就可以減少char所佔的位元組數,這樣記錄一多還是相當可觀的。

再例如表的photo的字段根本可以去掉,這樣更能減少字段,從而加快讀取的速度。因為photo欄位只是用來判斷使用者是否有**,而我們安全可以用photourl欄位來判斷。如photourl欄位的值如果為空,就表示此使用者沒有**,否則如果有的話,photourl欄位一定是有值的,同樣可以完成相應的功能。

例如我們要顯示出前10個使用者名稱的記錄。有的網友會進行如下的操作:

i=0set rs=conn.execute("select * from users")

do while not rs.eof and i<=10

i=i+1

response.write("name")&"

"rs.movenext

loop

這段**是可以完成上面的功能,可是如果真正的放到程式中,效率就太低了。因為下面的程式一下可是讀出了所有的記錄,即10000條啊,可我們只需要10條啊,如果這樣的話是不是太浪費啊,當然我們可以使用ms sql中的top命令來完成這個求,或是mysql中的limit命令。

另外,我們只需要使用者名稱的字段顯示出來,而其他的根本不需要,而此網友卻用了 "select *" 的命令,一下子讀了所有欄位的值,這是非常沒有必要的,而且在字段很多的情況下,更是加重了執行的負擔。所以說應該使用 "select 字段"來進行相應的操作。所以上面的程式可以修改為:

set rs=conn.execute("select top 10 name from users")

do while not rs.eof

response.write rs("name")&"

"rs.movenext

loop

這樣的話,在記錄很多的情況下,操作會快出很多。

另外在操作結束後,不需要再進行操作時,一定要關閉資料庫的連線。

set rs=nothing

set conn=nothing

有的網友說,原來是這樣啊,那他用下面的**來檢視users表中就可以用下面的**來完成了。

set rs=conn.execute("select name from users")

i=0do while not rs.eof

i=i+1

rs.movenext

loop

set rs=nothing

其實,這段**的效率仍然是非常低下的。為了知道表中有多少條記錄,而遍歷所有記錄,是非常不值的。我們完全可以用下面的**來實現:

set rs=conn.execute("select count(id) as num from users")

i=rs("num")

set rs=nothing

是不是很簡單呢,其實count()命令就可以統計出你所要查詢的記錄數,用where加上條件也可以。

如果一位使用者對資料庫一次要進行若干個操作的話,我們還要注意在操作後鎖定表,用lock操作完成後解鎖的步驟,用unlock,因為如果一位使用者在運算元據庫,另一位使用者也正在操作,容易造成資料的混亂,甚至使資料插錯記錄號,產生非常嚴重的後果。

在asp的操作中,對於資料庫的操作,分別有兩種方法,一種是直接引用conn.execute流,另一種是使用rs.open操作。兩種操作各有其好處,而在ms sql操作中,前者使用的比較多,因為它是一種單一流的操作,一般不能使用rs.addnew或rs.update等,因為此種操作要開啟表的寫操作才行,如rs.open sql,conn,3,3,後面的3就表示可以執行寫操作,而1表示是讀操作。

最後,應該要盡可能多的使用where條件,把多個語句合在一起。例如:顯示按積分的高低排列的最前面的10位男性使用者的使用者名稱。

看看一位網友下面的**:

set rs=conn.execute("select * from users order by cash desc")

i=0if i<=10 and not rs.eof then

if rs("***")='男' then

response.write rs("name")&"

"i=i+1

end if

rs.movenext

end if

set rs=nothing

這段**同樣可以完成上面的任務,可是效率實在是太低了,從資料庫中讀出的每一句還要進行一次判斷。對於性別的判斷完全可以放到where語句中,下面看看修改過的**:

set rs=conn.execute("select top 10 name from users where ***='男' order by cash desc")

do while not rs.eof

response.write rs("name")&"

"rs.movenext

loop

set rs=nothing

加上上面講到的top命令,select 欄位名,和where的條件判斷,不但使程式**減少很多,而且也會使得程式的執行效率大增。

其實提高sql語言的效率還有很多,只不過這些都是初學者朋友或是中級的朋友都會經常遇到,而又不在意的地方。希望大家能多多學習,廣開思路,不斷的從實踐中得到經驗。

由於本人的水平有限,如有錯誤和不足再所難免,盡請在http://luyu.***本站的論壇中提出,讓我們共同進步。

巧用快取提高asp程式的效能

巧用快取提高asp程式的效能 onlytiancai 原作 www.knowsky.com dim wawa if isempty wawa then wawa wawa get rows strconn,strsql end if wawa get list wawa end function p...

iOS開發如何提高

在現在這個碎片化閱讀流行的年代,部落格的風頭早已被微博蓋過。而我卻堅持寫作部落格,並且大量地閱讀同行的ios開發部落格。部落格的文章長度通常在3000字左右,許多ios開發知識都至少需要這樣的篇幅才能完整地講解清楚。並且部落格相對於書籍來說,並沒有較長的出版發行時間,所以閱讀部落格對於獲取最新的io...

ios開發如何提高

在現在這個碎片化閱讀流行的年代,部落格的風頭早已被微博蓋過。而我卻堅持寫作部落格,並且大量地閱讀同行的 ios 開發部落格。部落格的文章長度通常在 3000 字左右,許多 ios 開發知識都至少需要這樣的篇幅才能完整地講解清楚。並且部落格相對於書籍來說,並沒有較長的出版發行時間,所以閱讀部落格對於獲...