conn.execute的用法

2016-02-19 19:11 15 1 收藏

下面,图老师小编带您去了解一下conn.execute的用法,生活就是不断的发现新事物,get新技能~

【 tulaoshi.com - Web开发 】

  conn.execute、rs.open之间的差别conn.execute、rs.open、command.execute方法用法大大不同

  通常形成记录集可以使用

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  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比上一个性能要好那么一丁点
  ( command对象更灵活,执行范围更广)

  使用 CONN.execute 可以不用关闭直接执行下一个 set rs=conn.execute(SQL)
  但性能速度会大打折扣!!
  大约要慢 2~5倍!!(这是我在msSQL循环1000次亲自测试过的,不信你马上自己测试),所以执行下一个 rs=conn.execute之前!!一定要关闭掉!是

  个好习惯!
  使用单一对象的rs rs.open在open下一个记录集之前,必需要求显示关闭,否则出错,速度在SQL,CONN,0,1的情况下可前者基本一样

  所以我喜欢使用直设置一个 CreateObject("adodb.recordser"(在不需要多个记录集交错操作的情况下,多个也不碍是!)
  然后从头用到尾!!!
  开门关门开门关门
  最后一个 set rs=nothing 化上句号!

  更主要是 open提供非常灵活的操作数据库元数据的非常多的属性!!
  打开百宝箱,金光灿灿什么都看见!
  有很多情况下是非得用open来做的!
  而conn.execute 想黑布下换胶卷~~~偷偷摸摸~~非常单一!!!

  比如:

  rs1.open SQL1,conn,0,1
  rs.open SQL,conn,1,3
  if rs(0)0 then rs(0)=0
  rs(1)=aaa
  rs(2)=bbb
  rs.update ' 更新记录集写到数据库

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  rs.addnew '加一条新记录
  rs(0)=1
  rs(1)=ddd
  rs(2)=kkk
  rs.update
  id=rs(3) rs(s) '取的字段是自动编号 立即获得新记录的自动编号id //这是非常常用的

  rs1.addnew 对rs1添加关连使用id rs的新记录
  rs1("id"=id
  rs1(1)=...
  ..
  rs1.update

  rs1.close:set rs1=nothing
  rs.close:set rs=nothing

  
  上面的操作如果采用CONN.execute 则要用到四个 CONN.execute

  CONN.execute("update .."
  CONN.execute("insert into 表1:"
  rs=CONN.execute("select 新的自动 id"
  CONN.execute("insert into 表二"
  那一种方法逻辑条理更好,一目了然

  
  还有一个有趣的使用Recordset open记录的方法!!
  我想起来是有点费解

  Set rs=server.CreateObject("Adodb.recordset"
  Set rs=server.CreateObject("Adodb.recordset"

  rs.open SQL1,CONN
  rs.open SQL2,CONN

  这是同时设置同名的两个对象来打开两个记录集,而且是可用的!
  '只要取的列名合乎这两个记录集中元数据
  '则正常操作!!
  扩展开来

  Set rs=server.CreateObject("Adodb.recordset"
  Set rs=server.CreateObject("Adodb.recordset"
  Set rs=server.CreateObject("Adodb.recordset"
  Set rs=server.CreateObject("Adodb.recordset"

  rs.open SQL1,CONN
  rs.open SQL2,CONN
  rs.open SQL3,CONN
  rs.open SQL4,CONN

  这样大于二个同名的 rs我还没试过!!

  感觉有点相当与 SQL联合查询再打开记录集~~~
  以前我这样用过!!应该不是眼花!!
  ===============

  什么时候用什么?
  那就凭个人经验积累的感觉了:
  如果只需要一笔带过的碰碰数据库,用execute
  如果要对数据库作比较庞杂的操作!则最好用 rs.open

来源:http://www.tulaoshi.com/n/20160219/1620255.html

延伸阅读
标签: ASP
  DateDiff 函数        返回 Variant (Long) 的值,表示两个指定日期间的时间间隔数目。 语法 DateDiff(interval, date1, date2[, firstdayofweek][, firstweekofyear]]) DateDiff 函数语法中有下列命名参数: 部分 描述 interval 必要。字符串表达式,表示用来计算date1 和 date2 的时间差的时间间...
标签: 健康养生
吃过生姜后,人会有身体发热的感觉,这是因为它能使血管扩张,血液循环加快,促使身上的毛孔张开,这样不但能把多余的热带走,同时还把体内的病菌、寒气一同带出 1.生姜害的我们不长口腔溃疡了 用热姜水代茶漱口,每天二至三次。一般六至九次溃疡面可以收敛。 2.生姜害的我们牙周炎消肿了 先...
这是我用VB.NET做的一个Project内的一部分,在这里我主要介绍一下我在编程中使用Split函数新的认识。以前我在使用VB6.0时,对Split函数,只知道它可以用来拆开字符串。 项目要求提取指定文本文件导入至规定的数据表中,而数据表中部分字段信息就在用户所选择文本文件的文件名称中。文本文件名称如下列示: MCZ-2004-08-21-灯丝电压-0002-X-2...
标签: ASP
经常会在连接DB的时候用到,就是不知道代表什么意思。。。 RS.OPEN SQL,CONN,A,B A: ADOPENFORWARDONLY(=0) 只读,且当前数据记录只能向下移动 ADOPENKEYSET(=1) 只读,当前数据记录可自由移动 ADOPENDYNAMIC(=2) 可读写,当前数据记录可自由移动 ADOPENSTATIC(=3) 可读写,当前数据记录可自由移动,可看到新增记录 B: ADLOCKREADON...
标签: ASP
  RS.OPEN SQL,CONN,A,B A: ADOPENFORWARDONLY(=0) 只读,且当前数据记录只能向下移动 ADOPENKEYSET(=1) 只读,当前数据记录可自由移动 ADOPENDYNAMIC(=2) 可读写,当前数据记录可自由移动 ADOPENSTATIC(=3) 可读写,当前数据记录可自由移动,可看到新增记录 B: ADLOCKREADONLY(=1) 缺省锁定类型,记录集是只读的,不能修改记录 ...

经验教程

81

收藏

45
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部