设为首页 加入收藏

TOP

数据库主键自增插入显示值
2014-11-24 07:55:51 来源: 作者: 【 】 浏览:1
Tags:数据库 插入 显示

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,才能够插入!

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

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇SPA最佳实践 下一篇HowtouseSTA(sqltuningadvisor)

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Python爬虫教程(从 (2025-12-26 16:49:14)
·【全269集】B站最详 (2025-12-26 16:49:11)
·Python爬虫详解:原 (2025-12-26 16:49:09)
·Spring Boot Java: (2025-12-26 16:20:19)
·Spring BootでHello (2025-12-26 16:20:15)