当 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');

(0)

相关推荐