建表,主键自增

create table aaa(id bigint identity(1,1) not null PRIMARY key,name nvarchar(255));

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

把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 (‘王五',‘女');
dbcc checkident(表名,reseed,n);

也就是说:如果插入的是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字段的初始值重新设置为1insert into student4 values (‘王五',‘女');
set identity_insert 表名 on;insert into 表名(列名1,列名2,列名3,列名4) values (数据1,数据2,数据3,数据4);set identity_insert 表名 off;

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 (‘黑六',‘男');–errorinsert into student5 values (21,‘黑六',‘男');–error/insert into student5(sid,sname,ssex) values (21,‘黑六',‘男');set identity_insert student5 off;/insert into student5 values (22,‘赵七',‘女');–errorinsert into student5(sid,sname,ssex) values (22,‘赵七',‘女');–error*/insert into student5 values (‘赵七',‘女');

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Andorid Dialog 示例【慢慢更新】
  3. Android(安卓)PureMVC
  4. Ubunu下搭建android NDK环境
  5. 自定义SeekBar主题
  6. android SQLite数据库基本操作示例
  7. android draw bitmap 示例代码
  8. Android启动时启动Activity 的定义的位置
  9. Android适配器之------BaseAdapter(例子)

随机推荐

  1. 使用Ruby和Nokogiri模拟爬虫导出RSS种子
  2. C#对XML读写的代码实例
  3. XmlSlurper解析RSS的实例代码
  4. C#中通过xpath查找xml的指定元素的代码实
  5. php读取XML的四种方法实例详解
  6. 用C#实现XML和实体类之间序列化和反序列
  7. Android旋转动画xml配置的代码展示
  8. c#中xml操作类的代码详解
  9. Android伸缩动画xml配置的代码展示
  10. android读取xml的代码实例