欢迎光临
个人知识库,ERP、IT知识分享和应用

mssql server怎么设置id字段自增?

1> 通过 Microsoft SQL Server Management Studio (ssms)设计表时, 通过”标识规范”来实现:

标识规范,可以看到默认为否,代表不递增,如下图所示:

标识规范调为是,增量设置为1,点击保存按钮,

需要注意的是这种方法只在创建表的时候有用,如果已经创建表成功了,再来修改会出现错误,可以先删除,再重新创建添加id字段自增,如下图所示:

 

2> Create Table identity功能实现:

–创建表
CREATE TABLE [dbo].[#demo] (
[myid] INT identity(1,1),           –第一个1字, 表示的是初始值,第二个1字,表示的是每次自动增加的值
[myid2] INT DEFAULT(‘0’),       –创建默认值为 0 的字段
[custid] VARCHAR(300) COLLATE Chinese_PRC_CI_AS NULL,
[custname] VARCHAR(300) COLLATE Chinese_PRC_CI_AS NULL,
[jgshu] decimal(24,6) NULL,
[jgjin] decimal(24,6) NULL,
[ssshu] decimal(24,6) NULL,
[ssjin] decimal(24,6) NULL,
[hjshu] decimal(24,6) NULL,
[hjjin] decimal(24,6) NULL

)

附identity功能说明:

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 ('王五','女');

二、重新设置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 ('赵七','女');

 

其他参考示例:

主键 自增长列在进行数据插入的时候,很有用的,如可以获取返回的 自增 ID值,接下来将介绍SQL Server如何 设置主键 自增长列,
1.新建一数据表,里面有字段 id,将 id设为为主键

create table tb( id int,constraint pkid primary key ( id))
create table tb( id int primary key )

2.新建一数据表,里面有字段 id,将 id设为主键且自动编号

create table tb( id int identity(1,1),constraint pkid primary key ( id))
create table tb( id int identity(1,1) primary key )

3.已经建好一数据表,里面有字段 id,将 id设为主键

alter table tb alter column  id int not null
alter table tb add constraint pkid primary key ( id)

4.删除主键

Declare @Pk varChar(100);
Select @Pk=Name from sysobjects where Parent_Obj=OBJECT_ ID(‘tb’) and xtype=’PK’;
if @Pk is not null
exec(‘Alter table tb Drop ‘+ @Pk)
未经允许不得转载:Blog.XiaoMing.Xyz » mssql server怎么设置id字段自增?
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址