mysql主键自增为什么在插入的时候还要自己写主键值_数据库主键自增插入显示值...

 2023-09-18 阅读 25 评论 0

摘要:SQL Server 2008 数据库主键自增插入显示值 前几天在工作的时候遇到在删除数据库中表的数据的时候,删除之后,重新添加的数据没有得到原来的数据的id值(表中id为主键,且设置为自增) ,使用的是SQL Server 2008 ,现在已解决,和大家分享一下!

SQL Server 2008 数据库主键自增插入显示值 前几天在工作的时候遇到在删除数据库中表的数据的时候,删除之后,重新添加的数据没有得到原来的数据的id值(表中id为主键,且设置为自增) ,使用的是SQL Server 2008 ,现在已解决,和大家分享一下! 具体情况: 1.

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

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

具体情况:

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

1e9ef2ffd5bd892a34ce8d6b0fdaa36c.png

sql主键自增,2.向表中插入数据

由于表中的主键字段id为自增在插入的时候不需要指定显示插入,所以Sql 语句为

insert into [xxx].[dbo].[t_test] values ('xiaoming')

mysql增加自增主键?insert into [xxx].[dbo].[t_test] values ('hanmei')

insert into [xxx].[dbo].[t_test] values ('lilei')

insert into [xxx].[dbo].[t_test] values ('ligang')

mysql自增主键满了。insert into [xxx].[dbo].[t_test] values ('xiaozhi')

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

647a70f5baf524387227c556bda9c99b.png

3.删除数据,重新添加带有显示值的数据

delete [xxx].[dbo].[t_test] where id = 1

插入带有显示值的数据:

insert into [guagua_new_event_system_test].[dbo].[t_test] values (1,'xiaoming')

数据库提示:

消息 8101,级别 16,状态 1,第 1 行

仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表'xxx.dbo.t_test'中的标识列指定显式值。

重新设置INDENTITY_INSERT为ON时,重新重加,sql 语句为:

SET IDENTITY_INSERT [xxx].[dbo].[t_test] ON

insert into [xxx].[dbo].[t_test] values (1,'xiaoming')

数据库提示:

消息 8101,级别 16,状态 1,第 2 行

仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表'xxx.dbo.t_test'中的标识列指定显式值。

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

所以,正确的Sql 语句为:

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

只是在显示插入值的时候的时候需要制定列名,同时打开允许显示插入的INDENTITY_INSERT,才能够插入!

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

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/2/76431.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息