×

SQL中identity函数使用,以及修改自增方法

hqy hqy 发表于2024-12-13 17:28:48 浏览44 评论0

抢沙发发表评论

mportant;">第一部分

一、identity的基本用法

1.含义

 identity表示该字段的值会自动更新,不需要我们维护,通常情况下我们不可以直接给identity修饰的字符赋值,否则编译时会报错

2.语法

列名  数据类型  约束  identity(m,n)

m表示的是初始值,n表示的是每次自动增加的值

如果m和n的值都没有指定,默认为(1,1)

要么同时指定m和n的值,要么m和n都不指定,不能只写其中一个值,不然会出错

3.实例演示

不指定m和n的值

create table student1(    sid int primary key identity,    sname nchar(8) not null,    ssex nchar(1))insert into student1(sname,ssex) values ('张三','男');insert into student1 values ('李四','女');--可以省略列名insert into student1 values ('王五','女');

 

指定m和n的值

create table student2(    sid int primary key identity(20,5),    sname nchar(8) not null,    ssex nchar(1))insert into student2(sname,ssex) values ('张三','男');insert into student2 values ('李四','女');--可以省略列名insert into student2 values ('王五','女');

 

4.删除一条记录接着插入

把sid为2的记录删除,继续插入,新插入的记录的sid不是2,而是3

create table student3(    sid int primary key identity,    sname nchar(8) not null,    ssex nchar(1))insert into student3(sname,ssex) values ('张三','男');insert into student3 values ('李四','女');delete from student3 where sid=2;--把sid为2的记录删除insert into student3 values ('王五','女');

 

二、重新设置identity的值

1.语法

dbcc checkident(表名,reseed,n);

n+1表示的是表中identity字段的初始值(n的值可以为0)

也就是说:如果插入的是id为2的记录,则n的值是1

2.实例演示

create table student4(    sid int primary key identity,    sname nchar(8) not null,    ssex nchar(1))insert into student4(sname,ssex) values ('张三','男');insert into student4 values ('李四','女');delete from student4 where sid=2;--把sid为2的记录删除dbcc checkident('student4',reseed,1);--把student4表中identity字段的初始值重新设置为1insert into student4 values ('王五','女');

 

三、向identity字段插入数据

1.语法

set identity_insert 表名 on;
insert into 表名(列名1,列名2,列名3,列名4) values (数据1,数据2,数据3,数据4);
set identity_insert 表名 off;

注意:插入数据时必须得指定identity修饰的字段的名字

2.实例演示

create table student5(    sid int primary key identity(20,5),    sname nchar(8) not null,    ssex nchar(1))insert into student5(sname,ssex) values ('张三','男');insert into student5 values ('李四','女');insert into student5 values ('王五','女');set identity_insert student5 on;/*insert into student5 values ('黑六','男');--errorinsert into student5 values (21,'黑六','男');--error*/insert into student5(sid,sname,ssex) values (21,'黑六','男');set identity_insert student5 off;/*insert into student5 values (22,'赵七','女');--errorinsert into student5(sid,sname,ssex) values (22,'赵七','女');--error*/insert into student5 values ('赵七','女');



第二部分

一般情况下,当数据表中,莫一列被设置成了标识列之后,是无法向标识列中手动的去插入标识列的显示值。但是,可以通过设置SET IDENTITY_INSERT属性来实现对标识列中显示值的手动插入。

写法:

1).SET IDENTITY_INSERT 表名 ON :表示开启对标识列显示值插入模式,允许对标识列显示值进行手动插入数据。

2).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条数据,往标识列中手动插入显示值:

 代码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的显示值为8
insert 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的显示值为8
insert into b1(b_name) values('小宝')

set identity_insert b1 off --关闭对标识列的插入操作,标识列不允许手动插入显示值

插入结果:

 

说明:当设置IDENTITY_INSERT为ON时,必须要指定标识列中要插入的的显示值,要手动的插入标识列中的显示值。因为系统将不再对标识列的显示值自动插入了。所以,必须要手动去给标识列插入显示值。


打赏

本文链接:https://www.kinber.cn/post/4135.html 转载需授权!

分享到:


推荐本站淘宝优惠价购买喜欢的宝贝:

image.png

 您阅读本篇文章共花了: 

群贤毕至

访客