主頁(yè) > 知識(shí)庫(kù) > sqlserver主鍵自增的實(shí)現(xiàn)示例

sqlserver主鍵自增的實(shí)現(xiàn)示例

熱門標(biāo)簽:電銷機(jī)器人 深圳 股票配資電銷機(jī)器人 在電子版地圖標(biāo)注要收費(fèi)嗎 武漢AI電銷機(jī)器人 外呼系統(tǒng)會(huì)封嗎 萬(wàn)利達(dá)綜合醫(yī)院地圖標(biāo)注點(diǎn) 南京電銷外呼系統(tǒng)哪家好 地圖標(biāo)注如何弄全套標(biāo) 實(shí)體店地圖標(biāo)注怎么標(biāo)

建表,主鍵自增

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ù)類型 約束 identity(m,n)

m表示的是初始值,n表示的是每次自動(dòng)增加的值

如果m和n的值都沒(méi)有指定,默認(rèn)為(1,1)

要么同時(shí)指定m和n的值,要么m和n都不指定,不能只寫其中一個(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 垂直分表(減少程序改動(dòng))
  • sqlserver2017共享功能目錄路徑不可改的解決方法
  • SQLServer2008提示評(píng)估期已過(guò)解決方案
  • SQLServer2019 數(shù)據(jù)庫(kù)的基本使用之圖形化界面操作的實(shí)現(xiàn)
  • SQLServer2019 數(shù)據(jù)庫(kù)環(huán)境搭建與使用的實(shí)現(xiàn)
  • SQLServer 日期函數(shù)大全(小結(jié))
  • SQLServer2019配置端口號(hào)的實(shí)現(xiàn)
  • C語(yǔ)言中操作sqlserver數(shù)據(jù)庫(kù)案例教程

標(biāo)簽:武威 廣東 濟(jì)源 臺(tái)州 安徽 濟(jì)寧 泰安 汕頭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sqlserver主鍵自增的實(shí)現(xiàn)示例》,本文關(guān)鍵詞  sqlserver,主鍵,自增,的,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sqlserver主鍵自增的實(shí)現(xiàn)示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于sqlserver主鍵自增的實(shí)現(xiàn)示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章