项目场景:

数据库: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状态哦!

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐