SQL Server中identity(自增)的用法

目录

零、码仙励志

一、identity的基本用法

1.含义

2.语法

3.实例演示

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

二、重新设置identity的值

1.语法

2.实例演示

三、向identity字段插入数据

1.语法

2.实例演示


零、码仙励志

老要靠别人的鼓励才去奋斗的人不算强者;有别人的鼓励还不去奋斗的人简直就是懦夫

一、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字段的初始值重新设置为1
insert 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 ('黑六','男');--error
insert into student5 values (21,'黑六','男');--error
*/
insert into student5(sid,sname,ssex) values (21,'黑六','男');
set identity_insert student5 off;
/*
insert into student5 values (22,'赵七','女');--error
insert into student5(sid,sname,ssex) values (22,'赵七','女');--error
*/
insert into student5 values ('赵七','女');

本篇博客来自于郝斌老师视频教程的总结以及笔记的整理,仅供学习交流,切勿用于商业用途,如有侵权,请联系博主删除,博主QQ:194760901 

### 创建SQL Server中的自键值 在SQL Server中创建自键通常涉及定义一个具有`IDENTITY`属性的列。此方法适用于大多数情况下的表设计需求。 #### 使用T-SQL语句创建带有自主键的新表 当新建一张表格并希望其中某一列为自动长字段时,可以在建表命令里指定该列的数据类型以及设置其为标识列: ```sql CREATE TABLE Employees ( EmployeeID INT IDENTITY(1,1) PRIMARY KEY, FirstName NVARCHAR(50), LastName NVARCHAR(50), HireDate DATE ); ``` 上述代码片段展示了如何声明名为`EmployeeID`的整数类型的标识列作为主键[^2]。这里`(1,1)`表示起始值为1,并且每次新记录时递值也为1。 对于已经存在的表,在不破坏现有数据的前提下为其添加一个新的自主键,则需遵循特定的操作流程来确保不会引起重复键冲突等问题。如果尝试直接修改已有表结构可能会遇到错误提示,比如由于重新排序而导致主键冲突的情况[^3]。 为了安全地向旧表引入新的自主键,建议先备份原始数据,再按照如下方式操作: 1. 新建临时表用于存储转换期间的数据副本; 2. 将原表内容复制到新建立好的临时表内; 3. 删除原来的表; 4. 利用包含自特性的DDL语句重建目标表; 5. 把之前保存下来的信息迁移到更新后的架构下; 需要注意的是,虽然可以手动调整某些情况下产生的序列号断层现象,但这并不是推荐的做法,因为这可能会影响到依赖于这些编号的应用逻辑或其他关联对象的功能实现。 最后提醒一点,尽管默认配置能够满足大部分应用场景的需求,但在面对高并发写入或读取密集型的工作负载模式时,仍有必要评估不同索引策略的影响效果,从而选取最适合业务特点的设计方案[^4]。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值