欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > 数据库 >内容正文

数据库

数据库主键自增插入显示值

发布时间:2023/12/18 数据库 31 豆豆
生活随笔 收集整理的这篇文章主要介绍了 数据库主键自增插入显示值 小编觉得挺不错的,现在分享给大家,帮大家做个参考.
版权声明:本文为博主原创文章,未经博主同意不得转载。 https://blog.csdn.net/nwsuaf2009012882/article/details/32703597

SQL Server 2008 数据库主键自增插入显示值

前几天在工作的时候遇到在删除数据库中表的数据的时候。删除之后,又一次加入的数据没有得到原来的数据的id值(表中id为主键,且设置为自增) ,使用的是SQL Server 2008 ,如今已解决,和大家分享一下!

详细情况:

1.建立表t_test,设置主键自增,例如以下图


2.向表中插入数据

   因为表中的主键字段id为自增在插入的时候不须要指定显示插入。所以Sql 语句为

<span style="font-size:24px;">insert into [xxx].[dbo].[t_test] values ('xiaoming') insert into [xxx].[dbo].[t_test] values ('hanmei') insert into [xxx].[dbo].[t_test] values ('lilei') insert into [xxx].[dbo].[t_test] values ('ligang') insert into [xxx].[dbo].[t_test] values ('xiaozhi')</span>

再插入的时候并没有指定显示值id字段,数据库会自己主动添加主键id值,数据库中数据为:

3.删除数据,又一次加入带有显示值的数据

<span style="font-size:24px;">delete [xxx].[dbo].[t_test] where id = 1</span>插入带有显示值的数据:

<span style="font-size:24px;">insert into [guagua_new_event_system_test].[dbo].[t_test] values (1,'xiaoming')</span>数据库提示:

消息 8101,级别 16,状态 1,第 1 行
仅当使用了列列表而且 IDENTITY_INSERT 为 ON 时,才干为表'xxx.dbo.t_test'中的标识列指定显式值。

又一次设置INDENTITY_INSERT为ON时,又一次重加,sql 语句为:

<span style="font-size:18px;"> SET IDENTITY_INSERT [xxx].[dbo].[t_test] ON </span><span style="font-size:18px;"> insert into [xxx].[dbo].[t_test] values (1,'xiaoming')</span>数据库提示:

消息 8101。级别 16,状态 1,第 2 行
仅当使用了列列表而且 IDENTITY_INSERT 为 ON 时,才干为表'xxx.dbo.t_test'中的标识列指定显式值。

明明已经设置了INDENTITY_INSERT为ON,可是为什么还是没有加入进去,看了SQL Server 2008的帮助文档,才明确须要制定一一相应的列名在显示插入的时候。

所以,正确的Sql 语句为:

<span style="font-size:18px;">SET IDENTITY_INSERT [xxx].[dbo].[t_test] ON insert into [xxx].[dbo].[t_test](id ,name) values (1,'xiaoming') SET IDENTITY_INSERT [xxx].[dbo].[t_test] OFF</span>

仅仅是在显示插入值的时候的时候须要制定列名。同一时候打开同意显示插入的INDENTITY_INSERT,才可以插入。

--- --- 路漫漫其修远兮,吾将上下而求索



转载于:https://www.cnblogs.com/ldxsuanfa/p/10857294.html

总结

以上是生活随笔为你收集整理的数据库主键自增插入显示值的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。