html5中文学习网

您的位置: 首页 > 网络编程 > ASP编程 » 正文

rs.open和conn.execute的关系与区别_ASP教程_编程技术

[ ] 已经帮助:人解决问题
问:Rs.open和Rs.execute() 有什么不一样(RS为RECORDSET 对象)?在有些页面用set Rs=conn.execute() 不能用,有些Rs.open不能用

问:EXJHTML5中文学习网 - HTML5先行者学习网

Rs.open和Rs.execute()   有什么不一样(RS为RECORDSET   对象)?在有些页面用set   Rs=conn.execute()   不能用,有些Rs.open不能用EXJHTML5中文学习网 - HTML5先行者学习网

答:EXJHTML5中文学习网 - HTML5先行者学习网

第一个是可以有不同的打开游标  
  第二个只有一个向前的游标  
  而且你第二个写的好象不太正确应该是conn.execute,没有rs.execute的吧。EXJHTML5中文学习网 - HTML5先行者学习网

rexsp(真水无香   ppcode.com)   :  
        不好意思,写错了,是set   Rs=conn.execute()   ,如果我的游标conn.cursorLocation=3,set   Rs=conn.execute()   和Rs.open有什么不一样?EXJHTML5中文学习网 - HTML5先行者学习网

conn.execute   执行效率更高,尤其在insert   into   ,update等操作时!EXJHTML5中文学习网 - HTML5先行者学习网

两种打开方式有区别,就是前面说的游标问题。  
   
  一般情况下两种都互相换用,但有时候比如你需要取rs.recordcount的时候就只能用open来打开了。具体其他的差别我也不太清楚。我是一般用execute,在遇到问题时用openEXJHTML5中文学习网 - HTML5先行者学习网

    通常 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 像黑布下换胶卷~~~偷偷摸摸~~非常单一!!!
EXJHTML5中文学习网 - HTML5先行者学习网

EXJHTML5中文学习网 - HTML5先行者学习网
EXJHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
收藏文章
表情删除后不可恢复,是否删除
取消
确定
图片正在上传,请稍后...
评论内容为空!
还没有评论,快来抢沙发吧!
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助