安大互联
财经热点 > Asp编程 > rs.open和conn.execute的关系与区别
rs.open和conn.execute的关系与区别
浏览次数:【687】  发布日期:2009-8-13 12:09:22    文章分类:Asp编程   
专题:】 【
 

问:

Rs.open和Rs.execute()   有啥不一样(RS为RECORDSET   对象)?在有些页面用set   Rs=conn.execute()   不能用,有些Rs.open不能用

答:

第壹个是可以有不同样的打开游标  
  第贰个只有一个向前的游标  
  而且你第贰个写的好象不太正确应该是conn.execute,没有rs.execute的吧。

rexsp(真水无香   ppcode.com)   :  
        不好意思,写错了,是set   Rs=conn.execute()   ,如果我的游标conn.cursorLocation=3,set   Rs=conn.execute()   和Rs.open有啥不一样?

conn.execute   执行效率更高,尤其在insert   into   ,update等操作时!

两种打开方式有区别,就是前面说的游标问题。  
   
  一般情境下两种都互相换用,但有时候好比你需要取rs.recordcount的时候就只能用open来打开了。具体其它的不同我也不太清楚。我是一般用execute,在遇到问题时用open

    通常 Set   rs=CONN.execute(SQL) 或直接   rs=CONN.execute(SQL)   
    和     Set   rs=Server.CreateObject("ADODB.Recordset")   
       rs.open   SQL,CONN,0,1     或   rs.open   SQL,CONN  
       这种情景   通常open比上一个性能要好那么一丁点   
    
    使用 CONN.execute 可以不用关闭直接执行下一个 set rs=conn.execute(SQL) 
    但性能速度会大打折扣!!  
    大约要慢 2~5 倍!!(这是我在msSQL循环1000次亲自测试过的,不信你马上自己测试),所以执行下一个 rs=conn.execute之前!!务必要关闭掉!是个好习惯!  
    使用单一对象的rs  rs.open在open下一个记录集之前,务必要求显示关闭,不然犯错,速度在SQL,CONN,0,1的情景下可前者基本一样  
   
    所以我喜欢使用只设置一个 CreateObject("adodb.recordset")(在不用多个记录集交错操作的情景下,多个也不碍事!)  
    然后从头用到尾!!!  
    开门关门开门关门~~~~~咵踏咵踏~~~~  
    最后一个   set   rs=nothing   化上句号,爽!  
   
    更主要是 open提供非常灵活的操作数据库元数据的非常多的属性!!  
    打开百宝箱,金光灿灿啥都看见!  
    有许多情境下是非得用open来做的!  
    而conn.execute 像黑布下换胶卷~~~鬼鬼祟祟~~非常单一!!!

手机扫码浏览该文章
 ● 相关资讯专题
  • 网络建设业务咨询

   TEl:13626712526