当 IDENTITY_INSERT 设置为 OFF 时,不能为表中的标识列插入显式值
{"当 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');