上午在写一个NHibernate的演示Demo是出现一个异常,
{"当 IDENTITY_INSERT 设置为 OFF 时,不能向表 'OrderList' 中的标识列插入显式值"}
对于这个异常可以从两个角度来处理:A:数据库执行语句 B:直接修改NHibernate中持久化类映射配置文件id节点
A数据库执行语句:
问题描述:当在数据库表主键设计为 (Orderid int identity primary key),相对这个主键IDENTITY_INSERT默认设置为OFF,就是不能够显示插入主键id的值,例子如下:
insert into OrderList(id,OrderName) values(
4520
,
'
电子传票订单
'
)
执行上面语句会提示一个错误:
服务器: 消息
544
,级别
16
,状态
1
,行
1
当 IDENTITY_INSERT 设置为 OFF 时,不能向表 ' OrderList ' 中的标识列插入显式值。
当 IDENTITY_INSERT 设置为 OFF 时,不能向表 ' OrderList ' 中的标识列插入显式值。
其中关于主键一条记录,当我们想把这条记录的id设置成我们自定义的4520时出现上面的错误,如果我们添加一些设置,修改方法如下:
--
允许将显式值插入表的标识列中 ON
-
允许 OFF
-
不允许
set identity_insert OrderList ON -- 打开
insert into OrderList(id,ordername,createdate)
set identity_insert OrderList ON -- 打开
insert into OrderList(id,ordername,createdate)