码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2015-12-10 21:24:20      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:

问题描述:在SQL SERVER 2008中,向数据表中字段插入数据时,会报错,错误如下:

  当 IDENTITY_INSERT 设置为 OFF 时,不能向表 ‘OrderList‘ 中的标识列插入显式值。

解决方案:

1 --允许将显式值插入表的标识列中 ON-允许  OFF-不允许
2 set identity_insert OrderList ON--打开
3 4 insert into OrderList(id,ordername,createdate) 5 values(4520,set,getdate()) 6 7 set identity_insert OrderList OFF--关闭

在这个执行插入语句时,多了一个开关设置,设置如下:

 1 --语法:
 2 
 3 SET IDENTITY_INSERT [ database.[ owner.] ] { table } { ON | OFF } 
 4 允许将显式值插入表的标识列中
 5 
 6 参数说明:
 7 database:针对数据库
 8 table:针对某张表
 9 
10 ON:允许插入显式值插入标识列
11 OFF:不允许

注意:

  (1))任何时候,只有一个表的 IDENTITY_INSERT 属性可以设置为 ON。如果某个表已将此属性设置为 ON,并且为另一个表发出了 SET IDENTITY_INSERT ON 语句,则返回一个错误信息,指出 SET IDENTITY_INSERT 已设置为 ON 并报告此属性已设置为ON的表。

  (2)如果插入值大于表的当前标识值,则 SQL Server 自动将新插入值作为当前标识值使用。

  (3)SET IDENTITY_INSERT 的设置是在执行或运行时设置,而不是在分析时设置。

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

标签:

原文地址:http://www.cnblogs.com/wmcoder/p/5037140.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!