电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:123日期: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
相關文章:
主站蜘蛛池模板: ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | 拖链电缆_柔性电缆_伺服电缆_坦克链电缆-深圳市顺电工业电缆有限公司 | 阜阳在线-阜阳综合门户 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 亳州网络公司 - 亳州网站制作 - 亳州网站建设 - 亳州易天科技 | 双杰天平-国产双杰电子天平-美国双杰-常熟双杰仪器 | 超声波_清洗机_超声波清洗机专业生产厂家-深圳市好顺超声设备有限公司 | 免联考国际MBA_在职MBA报考条件/科目/排名-MBA信息网 | 注塑模具_塑料模具_塑胶模具_范仕达【官网】_东莞模具设计与制造加工厂家 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 精密模具制造,注塑加工,吹塑和吹瓶加工,EPS泡沫包装生产 - 济南兴田塑胶有限公司 | hdpe土工膜-防渗膜-复合土工膜-长丝土工布价格-厂家直销「恒阳新材料」-山东恒阳新材料有限公司 ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 刑事律师_深圳著名刑事辩护律师_王平聚【清华博士|刑法教授】 | 好杂志网-首页| 地图标注-手机导航电子地图如何标注-房地产商场地图标记【DiTuBiaoZhu.net】 | 玻璃钢格栅盖板|玻璃钢盖板|玻璃钢格栅板|树篦子-长沙川皖玻璃钢制品有限公司 | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 在线PH计-氧化锆分析仪-在线浊度仪-在线溶氧仪- 无锡朝达 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 悬浮拼装地板_篮球场木地板翻新_运动木地板价格-上海越禾运动地板厂家 | 除尘器布袋骨架,除尘器滤袋,除尘器骨架,电磁脉冲阀膜片,卸灰阀,螺旋输送机-泊头市天润环保机械设备有限公司 | 全自动面膜机_面膜折叠机价格_面膜灌装机定制_高速折棉机厂家-深圳市益豪科技有限公司 | WTB5光栅尺-JIE WILL磁栅尺-B60数显表-常州中崴机电科技有限公司 | ISO9001认证咨询_iso9001企业认证代理机构_14001|18001|16949|50430认证-艾世欧认证网 | 5L旋转蒸发器-20L-50L旋转蒸发器-上海越众仪器设备有限公司 | 无锡网站建设_企业网站定制-网站制作公司-阿凡达网络 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 活动策划,舞台搭建,活动策划公司-首选美湖上海活动策划公司 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 深圳离婚律师咨询「在线免费」华荣深圳婚姻律师事务所专办离婚纠纷案件 | MES系统工业智能终端_生产管理看板/安灯/ESOP/静电监控_讯鹏科技 | 紧急泄压人孔_防爆阻火器_阻火呼吸阀[河北宏泽石化] | 国标白水泥,高标号白水泥,白水泥厂家-淄博华雪建材有限公司 | 裹包机|裹膜机|缠膜机|绕膜机-上海晏陵智能设备有限公司 | 进口消泡剂-道康宁消泡剂-陶氏消泡剂-大洋消泡剂 | 共享雨伞_共享童车_共享轮椅_共享陪护床-共享产品的领先者_有伞科技 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | 游戏版号转让_游戏资质出售_游戏公司转让-【八九买卖网】 | 河南生物显微镜,全自动冰冻切片机-河南荣程联合科技有限公司 |