一.建表,主键自增
1
2
3
4
|
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的值
1
2
3
4
5
6
7
8
9
|
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的值
1
2
3
4
5
6
7
8
9
|
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
1
2
3
4
5
6
7
8
9
10
|
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.语法
1
|
dbcc checkident(表名,reseed,n); |
n+1表示的是表中identity字段的初始值(n的值可以为0)
也就是说:如果插入的是id为2的记录,则n的值是1
2.实例演示
1
2
3
4
5
6
7
8
9
10
11
|
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.语法
1
2
3
|
set identity_insert 表名 on ; insert into 表名(列名1,列名2,列名3,列名4) values (数据1,数据2,数据3,数据4); set identity_insert 表名 off ; |
注意:插入数据时必须得指定identity修饰的字段的名字
2.实例演示
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
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 (‘赵七 ",‘女" ); |
End.
作者:无极大帝
本文为转载分享,如果涉及作品、版权和其他问题,请联系我们第一时间删除(微信号:lovedata0520)
更多文章前往首页浏览http://www.itongji.cn/
- 我的微信公众号
- 微信扫一扫
- 我的微信公众号
- 微信扫一扫
评论