打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
当 IDENTITY_INSERT 设置为 OFF 时,不能为表中的标识列插入显式值
userphoto

2021.10.11

关注

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

对于这个异常可以从两个角度来处理:A:数据库执行语句  B:直接修改NHibernate中持久化类映射配置文件id节点

A数据库执行语句:

问题描述:当在数据库表主键设计为 (Orderid  int identity primary key),相对这个主键IDENTITY_INSERT默认设置为OFF,就是不能够显示插入主键id的值,例子如下:

insert into [Activity_2021]([id], [UserId], [ActivityId], [ContinuousSignInCount], [AddTime]) values(1007,33544133, 1001, 2, '2021-10-10 14:20:53.760')

执行上面语句会提示一个错误:

服务器: 消息 544,级别 16,状态 1,行 1
当 IDENTITY_INSERT 设置为 OFF 时,不能向表 
'Activity_2021' 中的标识列插入显式值。

其中关于主键一条记录,当我们想把这条记录的id设置成我们自定义的1007时出现上面的错误,如果我们添加一些设置,修改方法如下:

方式一:

--允许将显式值插入表的标识列中 ON-允许  OFF-不允许

set identity_insert  [Activity_2021] ON--打开

set identity_insert  [Activity_2021] OFF--关闭

在执行这个插入语句时多了一个设置,该设置的语法是

--设置语法:

方式一:

SET IDENTITY_INSERT [ database.[ owner.] ] { table } { ON | OFF } 
允许将显式值插入表的标识列中


方式二:

在插入语句中去掉([id]),不自定义id

INSERT INTO [Activity_2021] ([UserId], [ActivityId], [ContinuousSignInCount], [AddTime]) VALUES ( 33544133, 1007, 2, '2021-10-10 14:20:53.760');


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
SQLServer数据库自增长标识列的更新修改操作
SET IDENTITY_INSERT用法及理解
保存一个记录到数据库又马上返回ID号
【MySQL】触发器入门
一千行MySQL学习笔记
mysql更改用户权限[转]
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服