• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

sqlserver主键自增的实现示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

建表,主键自增

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 (‘赵七',‘女');

到此这篇关于sqlserver主键自增的实现示例的文章就介绍到这了,更多相关sqlserver主键自增内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Sqlserver创建用户并授权的实现步骤发布时间:2022-02-08
下一篇:
SQLServer2019配置端口号的实现发布时间:2022-02-08
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap