sqlserver追加主键(sqlserver主键自增的实现示例)
类别:数据库 浏览量:2511
时间:2021-09-30 00:01:12 sqlserver追加主键
sqlserver主键自增的实现示例建表,主键自增create table aaa( id bigint identity(1,1) not null PRIMARY key, name nvarchar(255) );
navicat没办法给主键列,加identity,只能用sql建表
赋值时,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 (‘王五',‘女');
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;–把sid为2的记录删除 insert into student3 values (‘王五',‘女');
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 (‘王五',‘女');
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 (‘赵七',‘女');
到此这篇关于sqlserver主键自增的实现示例的文章就介绍到这了,更多相关sqlserver主键自增内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- sql死锁进程保护(SqlServer查询和Kill进程死锁的语句)
- sqlserver2000安装之后在哪打开(SQL2000安装后,SQL Server组无项目解决方法)
- sqlserver索引介绍(浅析SQL Server的聚焦使用索引和查询执行计划)
- sqlserver如何查找值为null的数据(SQL Server中NULL的正确使用与空间占用)
- mysql 命令与sqlserver的区别大么(MySQL系列之执行SQL 语句时发生了什么?)
- sqlserver常用流控语句(SQL Server实现自动循环归档分区数据脚本详解)
- sqlserver存储删除过程(Sql中存储过程的定义、修改和删除操作)
- sqlserver厉害的函数(SQL Server里书签查找的性能伤害)
- SQLServer数据库从高版本降级到低版本实例详解(SQLServer数据库从高版本降级到低版本实例详解)
- sqlserver表值函数用法(SQL Server数据库中的表名称、字段比较)
- sqlserver统计表大小(SqlServer 垂直分表减少程序改动)
- sqlserver存储过程参数默认值(sql server使用临时存储过程实现使用参数添加文件组脚本复用)
- sqlserver数据库同步复制(SqlServer将数据库中的表复制到另一个数据库)
- sqlserver创建表结构时添加约束(SQL Server 通过with as方法查询树型结构)
- sqlserver数据库如何设置循环日志(sqlserver 实现收缩数据库日志操作)
- sqlserver创建带参数的存储过程(SQLServer存储过程实现单条件分页)
- 谷雨前,吃牛羊肉别忘了吃河鲜,除湿还清热,加紫苏一炒特解馋(吃牛羊肉别忘了吃河鲜)
- 紫苏牛肉锅里滚一滚,香的鼻子都要掉了(紫苏牛肉锅里滚一滚)
- 每天都吃水果的好处(每天吃水果的好处与功效)
- 苹果15价格(苹果15价格512g官网)
- 春节放假几天(春节放假几天2023法定几天)
- 今天 3月13日,31年前,一个英雄少年感动了中国(今天3月13日31年前)
热门推荐
- linux hadoop client 连接hbase(使用docker部署hbase的方法)
- web服务器与应用服务器的区别(web服务器是什么?web服务器有哪些呢?)
- 由dem数据可以获得哪些数据(详解GaussDBDWS explain分布式执行计划的示例)
- tomcat详细配置(Tomcat多实例部署及配置原理)
- css布局详细介绍(浅谈CSS 栅格系统布局原理分析)
- mysql自定义函数怎么设置(MySQL自定义变量?学不废不收费~)
- win7 ftp服务器怎么搭建(win7下利用IIS搭建FTP服务器)
- react跳转页面并传参数(react 跳转后路由变了页面没刷新的解决方案)
- SQL中的1=1影响性能吗?
- phpredis消息队列(PHP+redis实现微博的推模型案例分析)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9