最新消息: 关于Git&GitHub 版本控制你了解多少?
您现在的位置是:群英 > 数据库 > MySQL数据库 >
sqlserver怎样实现主键自增?有什么方法?
网络发表于 2021-08-28 17:40 次浏览

    这篇文章主要给大家介绍的是sqlserver实现主键自增的方法,小编觉得比较有用,因此分享给大家做个参考,感兴趣的朋友可以了解一下,下面一起跟随小编来学习一下吧。

    建表,主键自增

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 (‘李四',‘女');-C可以省略列名
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 (‘李四',‘女');-C可以省略列名
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;-C把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;-C把sid为2的记录删除
dbcc checkident(‘student4',reseed,1);-C把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 (‘黑六',‘男');-Cerror
insert into student5 values (21,‘黑六',‘男');-Cerror
/
insert into student5(sid,sname,ssex) values (21,‘黑六',‘男');
set identity_insert student5 off;
/
insert into student5 values (22,‘赵七',‘女');-Cerror
insert into student5(sid,sname,ssex) values (22,‘赵七',‘女');-Cerror
*/
insert into student5 values (‘赵七',‘女');

    关于sqlserver实现主键自增就介绍到这了,上述实例对大家学习和了解SQL主键自增有一定的帮助,需要的朋友可以借鉴学习,希望本文能对大家有帮助,想要了解更多sqlserver的操作,请关注群英网络其它相关文章。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
下一篇:没有了
相关信息推荐