IDENTITY_INSERT设置为OFF时,不能向表中插入显式值
Posted 讲个故事给你听
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了IDENTITY_INSERT设置为OFF时,不能向表中插入显式值相关的知识,希望对你有一定的参考价值。
项目场景:
数据库:SQL Server
数据表carsAll中ID是自增字段
问题描述:
insert的数据字段中包含自增的ID,在向数据库插入数据过程中出现了 IDENTITY_INSERT设置为OFF时,不能向表中插入显式值的问题
原因分析:
错误提示信息还是很友好,很明了的,已经告诉我们不能显式插入值了,就是说要插入值的字段中包含了数据库设计时默认自增的字段,默认自增就是让数据库表自己悄悄计数啊,所以默认自增的字段就是导致报错的原因了
解决方案:
原因找到了,再说说解决办法吧!
SET IDENTITY_INSERT 提示报错的表名 ON
INSERT INTO 报错的表名 (id,...) VALUES (1,...)
SET IDENTITY_INSERT 提示报错的表名 OFF
上面的SQL语句就是让这个表可以显式插入值,然后把数据添加进去,当然这样插入数据应该都是不得已,以后还是要遵守表ID自增的原则的,所以最后不要忘了恢复OFF状态哦!
以上是关于IDENTITY_INSERT设置为OFF时,不能向表中插入显式值的主要内容,如果未能解决你的问题,请参考以下文章
IDENTITY_INSERT设置为OFF时,不能向表中插入显式值
IDENTITY_INSERT设置为OFF时,不能向表中插入显式值
IDENTITY_INSERT设置为OFF时,不能向表中插入显式值
当 IDENTITY_INSERT 设置为 OFF 时,不能向表"*User" 中的标识列插入显示值