• 售前

  • 售后

热门帖子
入门百科

sqlserver主键自增的实现示例

[复制链接]
风来时狂放 显示全部楼层 发表于 2021-8-14 14:32:06 |阅读模式 打印 上一主题 下一主题
建表,主键自增
  1. create table aaa(
  2. id bigint identity(1,1) not null PRIMARY key,
  3. name nvarchar(255)
  4. );
复制代码
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. create table student1
  2. (
  3. sid int primary key identity,
  4. sname nchar(8) not null,
  5. ssex nchar(1)
  6. )
  7. insert into student1(sname,ssex) values (‘张三',‘男');
  8. insert into student1 values (‘李四',‘女');–可以省略列名
  9. insert into student1 values (‘王五',‘女');
复制代码
指定m和n的值
  1. create table student2
  2. (
  3. sid int primary key identity(20,5),
  4. sname nchar(8) not null,
  5. ssex nchar(1)
  6. )
  7. insert into student2(sname,ssex) values (‘张三',‘男');
  8. insert into student2 values (‘李四',‘女');–可以省略列名
  9. insert into student2 values (‘王五',‘女');
复制代码
4.删除一条记载接着插入

把sid为2的记载删除,继承插入,新插入的记载的sid不是2,而是3
  1. create table student3
  2. (
  3. sid int primary key identity,
  4. sname nchar(8) not null,
  5. ssex nchar(1)
  6. )
  7. insert into student3(sname,ssex) values (‘张三',‘男');
  8. insert into student3 values (‘李四',‘女');
  9. delete from student3 where sid=2;–把sid为2的记录删除
  10. insert into student3 values (‘王五',‘女');
复制代码
二、重新设置identity的值

1.语法
  1. dbcc checkident(表名,reseed,n);
复制代码
n+1表现的是表中identity字段的初始值(n的值可以为0)
也就是说:如果插入的是id为2的记载,则n的值是1
2.实例演示
  1. create table student4
  2. (
  3. sid int primary key identity,
  4. sname nchar(8) not null,
  5. ssex nchar(1)
  6. )
  7. insert into student4(sname,ssex) values (‘张三',‘男');
  8. insert into student4 values (‘李四',‘女');
  9. delete from student4 where sid=2;–把sid为2的记录删除
  10. dbcc checkident(‘student4',reseed,1);–把student4表中identity字段的初始值重新设置为1
  11. insert into student4 values (‘王五',‘女');
复制代码
三、向identity字段插入数据

1.语法
  1. set identity_insert 表名 on;
  2. insert into 表名(列名1,列名2,列名3,列名4) values (数据1,数据2,数据3,数据4);
  3. set identity_insert 表名 off;
复制代码
留意:插入数据时必须得指定identity修饰的字段的名字
2.实例演示
  1. create table student5
  2. (
  3. sid int primary key identity(20,5),
  4. sname nchar(8) not null,
  5. ssex nchar(1)
  6. )
  7. insert into student5(sname,ssex) values (‘张三',‘男');
  8. insert into student5 values (‘李四',‘女');
  9. insert into student5 values (‘王五',‘女');
  10. set identity_insert student5 on;
  11. /*
  12. insert into student5 values (‘黑六',‘男');–error
  13. insert into student5 values (21,‘黑六',‘男');–error
  14. /
  15. insert into student5(sid,sname,ssex) values (21,‘黑六',‘男');
  16. set identity_insert student5 off;
  17. /
  18. insert into student5 values (22,‘赵七',‘女');–error
  19. insert into student5(sid,sname,ssex) values (22,‘赵七',‘女');–error
  20. */
  21. insert into student5 values (‘赵七',‘女');
复制代码
到此这篇关于sqlserver主键自增的实现示例的文章就先容到这了,更多相干sqlserver主键自增内容请搜索脚本之家从前的文章或继承欣赏下面的相干文章盼望大家以后多多支持脚本之家!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作