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" 中的标识列插入显示值

[解决方案] 当 IDENTITY_INSERT 设置为 OFF 时

当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'T_Shell' 中的标识列插入显式值。