首页 / MYSQL / 数据库主键自增插入显示值
数据库主键自增插入显示值
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了数据库主键自增插入显示值,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2092字,纯文字阅读大概需要3分钟。
内容图文
![数据库主键自增插入显示值](/upload/InfoBanner/zyjiaocheng/563/13894f8baa934cf58a128deecbd03b69.jpg)
SQL Server 2008 数据库主键自增插入显示值 前几天在工作的时候遇到在删除数据库中表的数据的时候,删除之后,重新添加的数据没有得到原来的数据的id值(表中id为主键,且设置为自增) ,使用的是SQL Server 2008 ,现在已解决,和大家分享一下! 具体情况: 1.
SQL Server 2008 数据库主键自增插入显示值
前几天在工作的时候遇到在删除数据库中表的数据的时候,删除之后,重新添加的数据没有得到原来的数据的id值(表中id为主键,且设置为自增) ,使用的是SQL Server 2008 ,现在已解决,和大家分享一下!
具体情况:
1.建立表t_test,设置主键自增,如下图
2.向表中插入数据
由于表中的主键字段id为自增在插入的时候不需要指定显示插入,所以Sql 语句为
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')
再插入的时候并没有指定显示值id字段,数据库会自动增加主键id值,数据库中数据为:
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,才能够插入!
--- --- 路漫漫其修远兮,吾将上下而求索
内容总结
以上是互联网集市为您收集整理的数据库主键自增插入显示值全部内容,希望文章能够帮你解决数据库主键自增插入显示值所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。