在SQL Server数据库中为标识(IDENTITY)列插入显式值

忘记她的妩媚

忘记她的妩媚

2016-02-19 11:45

给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习图老师推荐的在SQL Server数据库中为标识(IDENTITY)列插入显式值,过去的都会过去,迎接崭新的开始,释放更美好的自己。
如果我们在标识列中插入值,例如:

insert member(id,username) values(10,'admin')

则在查询分析器里面会返回错误信息:
 引用内容
服务器: 消息 544,级别 16,状态 1,行 1
当 IDENTITY_Insert 设置为 OFF 时,不能向表 'member' 中的标识列插入显式值。

而在ASP程序中会返回错误信息:
 引用内容
Microsoft OLE DB Provider for SQL Server 错误 '80040e14' 

当 IDENTITY_Insert 设置为 OFF 时,不能向表 'member' 中的标识列插入显式值。 

test.asp,行 13 


但有的情况我们需要手动插入标识列的值,例如删除了一些记录后,标识列并不连续,而我们又想把它补齐。我们利用一个开关可以让愿望变成现实:

SET IDENTITY_Insert [TableName] ON

在查询分析器里面这样写:

SET IDENTITY_Insert member ON
insert member(id,username) values(1,'admin')
SET IDENTITY_Insert member OFF

在ASP页面可以这样写:

con.execute("SET IDENTITY_Insert member ON" & vbcrlf & "insert member(id,username) values(2,'abcde')" & vbcrlf & "SET IDENTITY_Insert member OFF")

使用该方法应该保证标识列没有插入重复数据,要不然会返回错误,插入操作不会进行。SET IDENTITY_Insert [TableName] OFF 其实可以省略,因为会话完毕后,这个开关就自动关上了。
展开更多 50%)
分享

猜你喜欢

在SQL Server数据库中为标识(IDENTITY)列插入显式值

编程语言 网络编程
在SQL Server数据库中为标识(IDENTITY)列插入显式值

sqlsever为标识列指定显式值

编程语言 网络编程
sqlsever为标识列指定显式值

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

在SQL Server 中如何得到刚刚插入的标识值

编程语言 网络编程
在SQL Server 中如何得到刚刚插入的标识值

CSharp读写SQL Server数据库中的Image列

电脑网络
CSharp读写SQL Server数据库中的Image列

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

Word中插入Access、SQL数据库数据

办公软件
Word中插入Access、SQL数据库数据

MDF文件在SQL Server数据库中恢复技术

SQLServer
MDF文件在SQL Server数据库中恢复技术

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

鼠标放上去则向上向下滚动的代码

鼠标放上去则向上向下滚动的代码

java代码之谜运算符篇

java代码之谜运算符篇
下拉加载更多内容 ↓