sqlserver主键自增的实现示例
作者:无极大帝 时间:2024-01-16 22:41:10
建表,主键自增
create table aaa(
id bigint identity(1,1) not null PRIMARY key,
name nvarchar(255)
);
navicat没办法给主键列,加identity,只能用sql建表
赋值时,identity列不能赋值,报错
一、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 (‘赵七',‘女');
来源:https://blog.csdn.net/mingwulipo/article/details/88553158
标签:sqlserver,主键,自增
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Python OpenCV一个窗口中显示多幅图像
2023-12-09 19:38:04
![](https://img.aspxhome.com/file/2023/6/82706_0s.jpg)
Oracle排名函数(Rank)实例详解
2024-01-21 16:44:34
深入解析Sync.Pool如何提升Go程序性能
2024-04-26 17:36:17
Python 实现还原已撤回的微信消息
2023-07-07 06:07:56
![](https://img.aspxhome.com/file/2023/8/126988_0s.jpg)
Anaconda中pkgs文件夹及如何清空PKGS
2022-04-03 00:31:33
![](https://img.aspxhome.com/file/2023/0/132400_0s.png)
mysql 常用数据库语句 小练习
2024-01-16 21:27:27
仿windows选项卡效果拾零
2013-07-13 09:33:42
javascript中注册和移除事件的4种方式
2024-04-22 12:49:02
深度辨析Python的eval()与exec()的方法
2021-09-06 21:46:04
MySQL备份与恢复之保证数据一致性(5)
2024-01-16 19:16:20
![](https://img.aspxhome.com/file/2023/4/104124_0s.jpg)
用 prototype 定义自己的方法
2010-03-17 20:44:00
Firebox 3 后退后按钮 diasabled 状态不恢复的一个解决方案
2008-11-06 12:28:00
python之生产者消费者模型实现详解
2021-12-03 14:37:15
对Tensorflow中权值和feature map的可视化详解
2021-03-31 22:24:39
![](https://img.aspxhome.com/file/2023/6/99276_0s.jpg)
python 插入日期数据到Oracle实例
2022-09-29 23:51:59
php5.4以下版本json不支持不转义内容中文的解决方法
2023-07-02 17:10:45
Golang函数这些神操作你知道哪些
2024-04-26 17:22:15
浅谈SQLite时间函数的使用说明与总结分析
2024-01-17 13:18:52
Python中如何向函数传递列表
2022-09-23 19:10:23
Python爬虫学习之requests的使用教程
2021-04-25 19:06:07
![](https://img.aspxhome.com/file/2023/1/95381_0s.png)