如题哦,刚学asp,问一下
1.
执行SQL操作时候
语句 rs.open sql,1,1 后面的1,1代表什么
几种操作比如select,delete,update,insert时候,后面的数字一样吗???能解释下么?
2.
为什么很多书里执行数据修改或者插入时候,都不使用SQL语句
而非要使用如下的
rs.addnew
rs.update....
修改也不用update table set..
非要传递给数据集然后rs.update
???
------解决方案--------------------
1、recordset.Open Source, ActiveConnection, CursorType, LockType, Options
Source 可选,变体型,计算 Command 对象的变量名、SQL 语句、表名、存储过程调用或持久 Recordset 文件名。
ActiveConnection 可选。变体型,计算有效 Connection 对象变量名;或字符串,包含 ConnectionString 参数。
CursorType 可选,CursorTypeEnum 值,确定提供者打开 Recordset 时应该使用的游标类型。可为下列常量之一(参阅 CursorType 属性可获得这些设置的定义)。
常量 说明
AdOpenForwardOnly (默认值)打开仅向前类型游标。
AdOpenKeyset 打开键集类型游标。
AdOpenDynamic 打开动态类型游标。
AdOpenStatic 打开静态类型游标。
LockType 可选。确定提供者打开 Recordset 时应该使用的锁定(并发)类型的 LockTypeEnum 值,可为下列常量之一(参见 LockType 属性可获得详细信息)。
常量 说明
AdLockReadOnly (默认值)只读 ― 不能改变数据。
AdLockPessimistic 保守式锁定(逐个) ― 提供者完成确保成功编辑记录所需的工作,通常通过在编辑时立即锁定数据源的记录。
AdLockOptimistic 开放式锁定(逐个) ― 提供者使用开放式锁定,只在调用Update 方法时才锁定记录。
AdLockBatchOptimistic 开放式批更新―用于批更新模式(与立即更新模式相对)。
Options 可选,长整型值,用于指示提供者如何计算 Source 参数(如果它代表的不是 Command 对象),或从以前保存 Recordset 的文件中恢复 Recordset。可为下列常量之一(参见 CommandType 属性可获得该列表中前五个常量的详细说明)。
常量 说明
adCmdText 指示提供者应该将 Source 作为命令的文本定义来计算。
adCmdTable 指示 ADO 生成 SQL 查询以便从在 Source 中命名的表中返回所有行。
adCmdTableDirect 指示提供者更改从在 Source 中命名的表中返回所有行。
adCmdStoredProc 指示提供者应该将 Source 视为存储过程。
adCmdUnknown 指示 Source 参数中的命令类型为未知。
adCmdFile 指示应从在 Source 中命名的文件中恢复保留(保存的)Recordset。
adAsyncExecute 指示应异步执行 Source。
adAsyncFetch 指示在提取 Initial Fetch Size 属性中指定的初始数量后,应该异步提取所有剩余的行。如果所需的行尚未提取,主要的线程将被堵塞直到行重新可用。
adAsyncFetchNonBlocking 指示主要线程在提取期间从未堵塞。如果所请求的行尚未提取,当前行自动移到文件末尾。
2、这个问题可以理解为个人爱好,当然也有具体的不同。在实践中去发现。
------解决方案--------------------
(1)它们的意义如下:
前一个1是游标类型,第二个是锁定类型,在ADODB.inc(好像是这个文件名)定义了一堆常量,其中就有这两个,但是必须要包含那个文件才可以使用,所以就都使用数值了
通常的写法主要有以下几种啊;
rs.open sql,1,1;
rs.open sql,1,3;
rs.open sql,3,3;
rs.open sql,3,2;
现在我分别跟你讲解一下它的主要含义啊;
第一个:
1,前向游标:即读取数据记录只能从前向后读,不能返回,并且不能反映读取同时其它用户对数据库的更新
2,静态游标,可向前和向后,但是不能反映其它用户的更新
3,动态游标,功能最强,当然也最耗资源
第二个
1,只读锁定,只能读不可以写的锁定数数据库
2,悲观锁定,从打开数据库开始锁定数据库,即锁定时其它用户无法更新数据库
3,乐观锁定,只在更新的瞬间锁定数据库
4,批量乐观锁定,在更新完一批以后提交到数据库时才锁定,如果有很多用户同时在更新数据库,则有可能更新到同一条记录
悲观锁定最不容易发生冲突,但是锁定时间太长,各有各的用途,实际应用时选择
(2)这个问题主要是看个人喜好啊!~我个人就比较喜欢用:
rs.addnew
.......
rs.update
这种写法啊!~所以嘛你如果对SQL语句情有独钟的话,那就用SQL语句啊!~