sqlserver主鍵自增的實(shí)現(xiàn)示例
建表,主鍵自增
create table aaa( id bigint identity(1,1) not null PRIMARY key, name nvarchar(255) );
navicat沒(méi)辦法給主鍵列,加identity,只能用sql建表
賦值時(shí),identity列不能賦值,報(bào)錯(cuò)
一、identity的基本用法
1.含義
identity表示該字段的值會(huì)自動(dòng)更新,不需要我們維護(hù),通常情況下我們不可以直接給identity修飾的字符賦值,否則編譯時(shí)會(huì)報(bào)錯(cuò)
2.語(yǔ)法
列名 數(shù)據(jù)類(lèi)型 約束 identity(m,n)
m表示的是初始值,n表示的是每次自動(dòng)增加的值
如果m和n的值都沒(méi)有指定,默認(rèn)為(1,1)
要么同時(shí)指定m和n的值,要么m和n都不指定,不能只寫(xiě)其中一個(gè)值,不然會(huì)出錯(cuò)
3.實(shí)例演示
不指定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的記錄刪除,繼續(xù)插入,新插入的記錄的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 (‘王五',‘女');
二、重新設(shè)置identity的值
1.語(yǔ)法
dbcc checkident(表名,reseed,n);
n+1表示的是表中identity字段的初始值(n的值可以為0)
也就是說(shuō):如果插入的是id為2的記錄,則n的值是1
2.實(shí)例演示
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字段的初始值重新設(shè)置為1 insert into student4 values (‘王五',‘女');
三、向identity字段插入數(shù)據(jù)
1.語(yǔ)法
set identity_insert 表名 on; insert into 表名(列名1,列名2,列名3,列名4) values (數(shù)據(jù)1,數(shù)據(jù)2,數(shù)據(jù)3,數(shù)據(jù)4); set identity_insert 表名 off;
注意:插入數(shù)據(jù)時(shí)必須得指定identity修飾的字段的名字
2.實(shí)例演示
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 (‘趙七',‘女');
到此這篇關(guān)于sqlserver主鍵自增的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)sqlserver主鍵自增內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SQLServer主鍵和唯一約束的區(qū)別
- 如何獲取SqlServer2005表結(jié)構(gòu)(字段,主鍵,外鍵,遞增,描述)
- 深入Mysql,SqlServer,Oracle主鍵自動(dòng)增長(zhǎng)的設(shè)置詳解
- SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識(shí)
- sqlserver主鍵設(shè)計(jì)的注意點(diǎn)
- sqlserver數(shù)據(jù)庫(kù)主鍵的生成方式小結(jié)(sqlserver,mysql)
- 小議sqlserver數(shù)據(jù)庫(kù)主鍵選取策略
- sqlserver設(shè)置主鍵的實(shí)現(xiàn)步驟
相關(guān)文章
SQLServer 2012中設(shè)置AlwaysOn解決網(wǎng)絡(luò)抖動(dòng)導(dǎo)致的提交延遲問(wèn)題
這篇文章主要介紹了SQLServer 2012中設(shè)置AlwaysOn解決網(wǎng)絡(luò)抖動(dòng)導(dǎo)致的提交延遲問(wèn)題,需要的朋友可以參考下2015-02-02sqlserver數(shù)據(jù)庫(kù)危險(xiǎn)擴(kuò)展刪除和恢復(fù)代碼
今天為了實(shí)現(xiàn)sqlserver的復(fù)制功能,因?yàn)橐郧皠h除了很多的sqlserver的一些會(huì)導(dǎo)致不安全因素的擴(kuò)展,導(dǎo)致很多功能無(wú)法用,沒(méi)有辦法需要重新的恢復(fù)擴(kuò)展。2010-07-07ROW_NUMBER SQL Server 2005的LIMIT功能實(shí)現(xiàn)(ROW_NUMBER()排序函數(shù))
SQL Server 2005新增了一個(gè)ROW_NUMBER()函數(shù),通過(guò)它可實(shí)現(xiàn)類(lèi)似MySQL下的LIMIT功能。下面的語(yǔ)法說(shuō)明摘自SQL Server 2005的幫助文件2012-06-06SQL SERVER 數(shù)據(jù)庫(kù)備份代碼實(shí)例
這篇文章主要介紹了SQL SERVER數(shù)據(jù)庫(kù)備份,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03解決在window下執(zhí)行SQLSERVER定時(shí)備份的問(wèn)題
這篇文章主要介紹了在window下執(zhí)行SQLSERVER的定時(shí)備份,文末給大家介紹了windows任務(wù)計(jì)劃定時(shí)備份sqlserver數(shù)據(jù)庫(kù)的相關(guān)知識(shí),使用windows的任務(wù)計(jì)劃新建一個(gè)sqlserver數(shù)據(jù)庫(kù)的定時(shí)備份任務(wù),需要的朋友可以參考下2022-01-01SQL 特殊狀態(tài)“未知“以及“空值NULL“的判斷
Null值是SQL中的一個(gè)特殊值,表示缺少值或未知值,還有未知(UNKNOWN),表示無(wú)法判斷出真或者假,本文主要介紹了SQL 特殊狀態(tài)“未知“以及“空值NULL“的判斷,感興趣的可以了解一下2023-11-11Activiti-Explorer使用sql server數(shù)據(jù)庫(kù)實(shí)現(xiàn)方法
本文主要介紹Activiti-Explorer使用sql server數(shù)據(jù)庫(kù),這里整理了詳細(xì)的資料來(lái)說(shuō)明Activiti-Explorer使用SQL Server的實(shí)例,有興趣的小伙伴可以參考下2016-08-08