成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

asp程序執行數據庫的效率提升建議

瀏覽:208日期:2022-06-04 17:07:09

很多網友非常不喜歡用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  //年齡 
Sex  char  2  //性別  默認值為  "男" 
Address  nvchar  255  //地址 
Cash  int  4  //積分 
Photo  char  2  //是否有照片  默認值為  "沒有" 
PhotoUrl  nvchar  255  //照片路徑    

   首頁我們講講關于數據庫中表和字段的問題,對于WEB進行的數據庫對象中,自然表的個數越少,越好;表中的安段個數越少,越好;字段中所占的字節是越少,越好。 
  例如Users表中sex的字段完全可以用bit字段,進行0或1的操作,可以定義  "0"為男性,而  "1"為女性,這樣就可以減少char所占的字節數,這樣記錄一多還是相當可觀的。 
  再例如表的Photo的字段根本可以去掉,這樣更能減少字段,從而加快讀取的速度。因為Photo字段只是用來判斷用戶是否有照片,而我們安全可以用PhotoUrl字段來判斷。如PhotoUrl字段的值如果為空,就表示此用戶沒有照片,否則如果有的話,PhotoUrl字段一定是有值的,同樣可以完成相應的功能。 
 
例如我們要顯示出前10個用戶名的記錄。有的網友會進行如下的操作:  

I=0 
Set rs=conn.execute("select * from users") 
Do while not rs.eof and I<=10 
I=I+1 
Response.write("name")&"<br>" 
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")&"<br>" 
rs.movenext 
loop 

這樣的話,在記錄很多的情況下,操作會快出很多。 
另外在操作結束后,不需要再進行操作時,一定要關閉數據庫的連接。 

Set  rs=nothing 
Set  conn=nothing 

有的網友說,原來是這樣啊,那他用下面的代碼來查看Users表中就可以用下面的代碼來完成了。 

Set rs=conn.execute("select name from users") 
I=0 
Do 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=0 
If I<=10 and not rs.eof then 
If rs("sex")="男" then 
Response.write rs("name")&"<br>" 
I=I+1 
End if 
Rs.movenext 
End if 
Set rs=nothing 

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

set rs=conn.execute("select top 10 name from users where sex="男" order by cash desc") 
do while not rs.eof 
response.write rs("name")&"<br>" 
rs.movenext 
loop 
set rs=nothing 

加上上面講到的top命令,select  字段名,和where的條件判斷,不但使程序代碼減少很多,而且也會使得程序的執行效率大增。 
  其實提高SQL語言的效率還有很多,只不過這些都是初學者朋友或是中級的朋友都會經常遇到,而又不在意的地方。希望大家能多多學習,廣開思路,不斷的從實踐中得到經驗

到此這篇關于asp程序執行數據庫的效率提升建議的文章就介紹到這了,更多相關asp數據庫效率內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: ASP
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美日韩亚洲免费| 92精品国产成人观看免费| 欧美老人xxxx18| 丁香另类激情小说| 国产精品色在线| 色婷婷久久久亚洲一区二区三区| 中文字幕精品—区二区四季| 黄色av一区| 91精品国产综合久久婷婷香蕉 | 中文字幕亚洲欧美在线不卡| 97se狠狠狠综合亚洲狠狠| 日韩三级在线免费观看| 国产美女一区二区三区| 欧美年轻男男videosbes| 极品少妇xxxx精品少妇偷拍| 日本高清成人免费播放| 日韩国产在线一| 新狼窝色av性久久久久久| 一区二区三区欧美视频| av不卡在线| 亚洲福利一区二区三区| 久久国产99| 日韩电影免费在线看| 欧美一级播放| 亚洲国产精品一区二区久久恐怖片| 国产区欧美区日韩区| 一区二区三区丝袜| 久久国产精品一区二区三区四区| 无吗不卡中文字幕| 91国产精品成人| 精品午夜一区二区三区在线观看| 欧美日韩一级二级| 国产精品中文字幕日韩精品| 91精品在线一区二区| 国产精品性做久久久久久| 欧美精品 日韩| 国产成人综合在线| 欧美精品一区二区三区久久久 | 欧美精品日日鲁夜夜添| 国产一区二区h| 日韩欧美一区二区三区在线| fc2成人免费人成在线观看播放| 久久夜色精品国产噜噜av| 欧美在线91| 亚洲欧美国产毛片在线| 乱人伦精品视频在线观看| 日韩精品一级二级 | 91在线免费播放| 国产精品国产三级国产有无不卡| 亚洲欧洲三级| 免费欧美高清视频| 精品免费国产一区二区三区四区| 欧美日韩在线不卡一区| 一区二区高清在线| 欧美中文字幕一区二区三区亚洲| 国产最新精品免费| 久久久亚洲国产美女国产盗摄 | 亚洲午夜黄色| 亚洲精品国产精华液| 一本大道av一区二区在线播放| 国产一区二区三区美女| 国产区在线观看成人精品| 99伊人成综合| 国产一区欧美二区| 中文字幕国产精品一区二区| 香蕉久久夜色精品| 国产激情视频一区二区在线观看| 国产偷v国产偷v亚洲高清 | 欧美一级免费大片| 国产精品v欧美精品v日韩| 亚洲与欧洲av电影| 欧美日韩国产电影| 91网站在线播放| 一区二区三区国产精品| 欧美日韩精品一区二区三区| 色综合视频一区二区三区高清| 一区二区三区精品| 91精品福利在线一区二区三区 | 欧美大片一区二区| 亚洲美女少妇无套啪啪呻吟| 久草在线在线精品观看| 国产亚洲综合在线| 香港久久久电影| 国产一区二区免费视频| 日本一区二区高清| 久久一区二区三区超碰国产精品| 成人一区二区三区视频| 亚洲自拍偷拍网站| 日韩精品一区二区三区三区免费| 999亚洲国产精| 国产成人精品一区二区三区四区| 亚洲黄色av一区| 日韩精品一区二区三区三区免费| 国产精品一区二区你懂得| 风流少妇一区二区| 亚洲国产另类精品专区| 亚洲精品一区二区三区福利| 亚洲欧美日韩在线观看a三区| 国产精品99久久久久久有的能看 | 国产色一区二区| 日本韩国一区二区三区视频| 午夜精彩国产免费不卡不顿大片| 日韩不卡一区二区三区| 久久―日本道色综合久久 | 日韩欧美一级在线播放| 国产伦精品一区二区三区照片91| 成人小视频免费在线观看| 亚洲一区二区av电影| 日韩精品一区二区三区四区| 噜噜噜91成人网| 女人香蕉久久**毛片精品| 日本va欧美va精品发布| 国产日韩综合av| 欧美性猛交xxxxxx富婆| 亚洲国产欧美不卡在线观看| 成人永久免费视频| 丝袜国产日韩另类美女| 欧美韩日一区二区三区| 欧美高清视频一二三区| 亚洲精美视频| 国产精品99久久久久久似苏梦涵 | 欧美日韩三级电影在线| 久草在线在线精品观看| 亚洲精品国产无天堂网2021| 日韩三级视频在线观看| 亚洲欧美日韩综合一区| 女主播福利一区| 国产精品77777| 五月激情综合网| 综合激情网...| 日韩欧美国产小视频| 美女久久一区| 狠狠干成人综合网| 不卡av在线网| 精品午夜一区二区三区在线观看| 亚洲国产精品自拍| 亚洲特黄一级片| 精品国精品国产尤物美女| 欧美色手机在线观看| 免费在线成人av| 亚洲国产精品久久久久婷婷老年| www.欧美日韩国产在线| 精品一区免费av| 亚洲国产精品久久人人爱| 国产精品免费丝袜| 久久伊99综合婷婷久久伊| 欧美午夜在线观看| 亚洲影视综合| 黄色日韩在线| 色综合久久综合网欧美综合网 | 2017欧美狠狠色| 91精品国产综合久久婷婷香蕉 | 强制捆绑调教一区二区| 亚洲与欧洲av电影| 亚洲色图一区二区| 国产清纯美女被跳蛋高潮一区二区久久w | 国内精品久久国产| 91免费看视频| 国产黄人亚洲片| 奇米影视一区二区三区| 亚洲国产成人va在线观看天堂| 国产精品久久久久久久蜜臀| 久久精品在线观看| 精品区一区二区| 欧美一区二区黄色| 欧美一区二区三区电影| 欧美性xxxxxx少妇| 欧美视频一区二区| 91福利视频久久久久| 性久久久久久| 99视频精品| 亚洲精选在线| 亚洲黄色三级| 亚洲国产精品视频一区| 欧美极品一区| 欧美成人午夜| 欧美精品一区三区在线观看| 99精品1区2区| 欧美在线1区| 好吊日精品视频| 亚洲国产免费| 国产精品美女久久久| 国产精品久久久久久久久久妞妞| 99视频国产精品免费观看| 国产亚洲一级| 奶水喷射视频一区| 久久久久se| 在线看日韩精品电影| 欧美性生活一区| 欧美美女黄视频| 91精品婷婷国产综合久久性色 | 欧美sm极限捆绑bd| 欧美mv和日韩mv国产网站| 日韩视频一区二区| 精品国产污污免费网站入口| 2021久久国产精品不只是精品| 国产欧美精品一区aⅴ影院| 最新欧美精品一区二区三区| 亚洲在线观看免费视频| 日韩精品乱码免费|