运维开发网

SQL IDENTITY_INSERT用例的详细介绍

运维开发网 https://www.qedev.com 2022-05-14 17:04 出处:网络
这篇文章主要介绍了SQL IDENTITY_INSERT作用案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

这篇文章主要介绍了SQL IDENTITY_INSERT作用案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

一般情况下,当生产任务列设置为数据表中的标识列时,不能手工将标识列的显示值插入到标识列中。但是,您可以通过设置SET IDENTITY_INSERT属性来手动插入标识列中显示的值。

写作:

SET IDENTITY_INSERT 表名 ON :表示开启对标识列显示值插入模式,允许对标识列显示值进行手动插入数据。 SET IDENTITY_INSERT 表名 OFF:表示关闭对标识列显示值的插入操作,标识列不允许手动插入显示值。

注意:IDENTITY_INSERT的ON和OFF是成对的,所以在手动插入操作之后,记得将IDENTITY_INSERT设置为OFF,否则下一次自动数据插入将会失败。

例如:

创建一个表b1,其中b_id是标识列,并设置为唯一标识。从1开始,每插入一次新数据,该值递增1,不允许为空:

CREATE table b1(b_id int identity(1,1) primary key not null, b_name varchar(20) null)

当表b1中的列b_id设置为唯一标识列时,IDENTITY_INSERT属性的值默认设置为OFF。标记列b_id列不允许手动插入显示值,显示值只能由系统根据行顺序自动插入。

1.当IDENTITY_INSERT 为OFF时,往表b1中插入2条数据,往标识列中手动插入显示值:

#160;代码1:

insert into b1(b_id,b_name) values(1,'莉莉')insert into b1(b_id,b_name) values(2,'阿呆')

插入结果:


代码2:

insert into b1(b_name) values('莉莉')insert into b1(b_name) values('阿呆')

插入结果:


注意:当IDENTITY_INSERT设置为OFF时,不允许手动插入标识列的显示值。只有系统可以自动插入标识列的显示值。

2.当IDENTITY_INSERT 为ON时,往表b1中插入2条数据,往标识列中手动插入显示值:

代码1:

set identity_insert b1 on --开启对标识列的插入模式,标识列允许手动插入显示值insert into b1(b_id,b_name) values(8,'小白') --手动去插入标识列b_id的显示值为8insert into b1(b_id,b_name) values(9,'小黑')set identity_insert b1 off --关闭对标识列的插入操作,标识列不允许手动插入显示值

插入结果:


代码2:

set identity_insert b1 on --开启对标识列的插入模式,标识列允许手动插入显示值insert into b1(b_name) values('小胖') --手动去插入标识列b_id的显示值为8insert into b1(b_name) values('小宝')set identity_insert b1 off --关闭对标识列的插入操作,标识列不允许手动插入显示值

插入结果:


注意:将IDENTITY_INSERT设置为ON时,必须指定要在标识列中插入的显示值,并在标识列中手动插入显示值。因为系统将不再自动插入标识列的显示值。因此,需要手动将显示值插入标识列。

关于SQL IDENTITY_INSERT的动作案例的详细说明,本文到此为止。更多SQL IDENTITY_INSERT相关内容

0

精彩评论

暂无评论...
验证码 换一张
取 消