asp mysql 更新_ASP入门(二十三)- 数据库插入、更新和删除操作

我们这里介绍如何使用 Recordset 对象进行插入、更新和删除操作,顺便和 SQL 语句对比。

插入记录

AddNew 方法用于插入一条记录,首先打开一个记录集,并且这个记录具备可写特性,而后调用 AddNew 方法告诉 ADO 要插入一条记录,而后分别设置各个字段的值,最后调用 Update 方法将插入的记录生效。

还是直接看具体代码和注释吧(AddNew.asp),如下:

DimoRs, sql

sql= "SELECT * FROM [产品]"

SetoRs=Server.CreateObject("ADODB.Recordset")

oRs.Open sql, oConn,1,3 '这个3表示可修改'调用 AddNew 准备插入记录

oRs.AddNew()

oRs("产品名称")= "巧克力面包"oRs("供应商ID")= 8oRS("类别ID")= 3oRS("单位数量")= "个"oRS("单价")= 5oRS("库存量")= 150oRS("订购量")= 50oRS("再订购量")= 25oRS("中止")= FalseoRs.Update

oRs.CloseSetoRs= Nothing

'/'SQL 版本的插入执行

DimRA

sql= "INSERT INTO 产品 ( 产品名称, 供应商ID, 类别ID, 单位数量, 单价, 库存量, 订购量, 再订购量, 中止 ) VALUES ('奶油面包', 8, 3, '个', 3, 200, 50, 25, False)"oConn.Execute sql, RAIfRA<> 0 ThenResponse.Write("插入记录成功")End IfoConn.CloseSetoConn= Nothing

%>

执行后,我们在 Access 中发现已经插入 2 条新记录了,如下图:

1c6825eb081cdcfa9537b5e6ede575da.gif

更新记录

更新记录仅仅需要将记录集的指针移动到相应的位置,而后是更新记录,最后调用 Update 方法进行更新即可。

还是来看代码和注释吧(UpdateRecord.asp),如下:

DimoRs, sql

sql= "SELECT * FROM [产品]"

SetoRs=Server.CreateObject("ADODB.Recordset")

oRs.Open sql, oConn,1,3 '这个3表示可修改

oRs.MoveLast'移动到最后一条记录

oRs("产品名称")= "我被修改了"oRs.Update

oRs.CloseSetoRs= Nothing

'/'SQL 版本的更新记录

DimRA

sql= "UPDATE 产品 SET [产品名称]='我被修改了' WHERE [产品ID]=(SELECT MIN([产品ID]) FROM 产品)"oConn.Execute sql, RAIfRA<> 0 ThenResponse.Write("更新记录成功")End IfoConn.CloseSetoConn= Nothing

%>

执行后,我们通过 Access 发现第一条和最后一条记录已经被修改了,查询结果如下:

79c922652d7a493828124fafd862269c.gif

删除记录

删除语句则是将记录集指针要移动到相应位置后,直接调用 Delete 方法,即可。

具体实现的代码(DeleteRecord.asp)如下:

DimoRs, sql

sql= "SELECT * FROM [产品]"

SetoRs=Server.CreateObject("ADODB.Recordset")

oRs.Open sql, oConn,1,3 '这个3表示可修改

oRs.MoveFirst'定位到第一条记录

oRs.Delete()

oRs.Update

oRs.CloseSetoRs= Nothing

'/'SQL 版本的更新记录

DimRA

sql= "DELETE FROM 产品 WHERE [产品ID]=(SELECT MIN([产品ID]) FROM 产品)"oConn.Execute sql, RAIfRA<> 0 ThenResponse.Write("删除记录成功")End IfoConn.CloseSetoConn= Nothing

%>

执行后,我们通过 Access 查看执行的效果,结果什么也没有删除,原因是其他表“订单明细”中包含了相关记录,不能删除或改变记录。如果要删除需要先删除关系的表中的记录。我们在“关系”视图中将产品表和订单明细表的“编辑关系”对话框中勾选上“级联删除相关记录”选项,这样就能删除了。

再次执行 ASP 页面代码,Access 中产品表删除前后的对比结果如下:

3257b5435192e25edf1f0246383b8c0e.gif

b6384171db3a002de505346af1b6cf17.gif

Open 方法的常用参数

在上面的代码中,我们已经看到 Recordset 对象在使用Open 方法时传了几个参数,如下代码:

oRs.Open sql, oConn, 1, 3

其中 sql 和 oConn 两个含义我们已经知道了,分别是打开记录集所使用的 SQL 语句和数据库连接对象。后面的 1 和 3 是什么意思呢?

我们先看看Recordset 对象的 Open 方法定义:

Recordset.Open Source, ActiveConnection, CursorType, LockType, Options

游标类型(CursorType)指定了记录集中游标指针的移动方法,它的可选值在 adovbs.inc 文件中有记录,该文件你可以在你的 C:\Program Files\Common Files\System\ado 这个位置找到该文件。如下:

'---- CursorTypeEnum Values ----

ConstadOpenForwardOnly= 0

ConstadOpenKeyset= 1

ConstadOpenDynamic= 2

ConstadOpenStatic= 3

%>

adOpenForwardOnly 使用仅向前的游标。扯了在记录中只能向前滚动外,与静态游标相同。当只需要在 Recordset 中进行一个传递时,用它提高性能。

adOpenKeyset 使用键集游标。尽管从您的 Recordset 不能访问其他用户删除的记录,但除无法查看其他用户添加的记录外,它和动态游标相似。其他用户所做的数据更改依然能见。

adOpenDynamic 使用动态游标,其他用户所做的添加、更改和删除均可见,而且允许 Recordset 中所有移动类型。

adOpenStatic 使用静态游标。一组记录的静态副本,可用于查找数据或生成报告。其他用户所做的添加、更改和删除不可见。

adOpenUnspecified 不指定游标类型 (-1)。

锁定类型(LockType)可选参数如下:

'---- LockTypeEnum Values ----

ConstadLockReadOnly= 1

ConstadLockPessimistic= 2

ConstadLockOptimistic= 3

ConstadLockBatchOptimistic= 4

%>

adLockReadOnly Recordset对象以只读方式启动,无法运行增、删、改等操作

adLockPessimistic 当数据源正在更新时,系统会锁定其他用户的动作,以保证数据的一致性

adLockOptimistic 当数据源正在更新时,系统不会锁定其他用户的动作,其他用户可以对数据进行操作。只有在调用 Update 方法时才锁定记录。

adLockBatchOptimistic 当数据源正在更新时,其他用户必须将 CursorLocation 改为 adUdeClientBatch 才能对数据进行增、删、改等操作。

当您首次打开一个 Recordset 时,当前记录指针指向第一个记录,同时 BOF 和 EOF 属性都是 False。如果没有记录则 BOF 和 EOF 属性都是 True。

示例代码下载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值