服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - ASP教程 - SQL"不能为新插入的行确定标识"错误的解决方法

SQL"不能为新插入的行确定标识"错误的解决方法

2019-09-19 11:46asp教程网 ASP教程

下列代码运行将出错(不能为新插入的行确定标识),即新记录不能为自己的另一个字段赋予新生成标识的值

这种情况在Access下可以通过,但SQL则不行,在百度搜索解决方法,发现N多人出现同样问题却找不到解决办法: 

复制代码代码如下:


set rs=server.CreateObject("adodb.recordset") 
rs.open "select * from t1",conn,1,3 
rs.addnew() 
rs("data")="abc123" 
rs.update 
rs("data")=rs("id") 
rs.update 
rs.close 
conn.close 


(注:id字段为标识值(identity(1,1)) ) 

在SQL数据库下,只能用以下的方法: 

复制代码代码如下:


dim newID 
set rs=server.CreateObject("adodb.recordset") 
rs.open "select * from t1",conn,1,3 
rs.addnew() 
rs("data")="abc123" 
rs.update 
newID=rs("id") 
'这里注意,cursorType必须为1才能正确获取标识值,且必须update()后获取 
rs.close 
rs.open "select * from t1 where id=" &newID,conn,1,3 
rs("data")=newID 
rs.update 
rs.close 
conn.close

延伸 · 阅读

精彩推荐