SQL IDENTITY_INSERT作用案例詳解
一般情況下,當(dāng)數(shù)據(jù)表中,莫一列被設(shè)置成了標(biāo)識列之后,是無法向標(biāo)識列中手動的去插入標(biāo)識列的顯示值。但是,可以通過設(shè)置SET IDENTITY_INSERT屬性來實現(xiàn)對標(biāo)識列中顯示值的手動插入。
寫法:
- SET IDENTITY_INSERT 表名 ON :表示開啟對標(biāo)識列顯示值插入模式,允許對標(biāo)識列顯示值進行手動插入數(shù)據(jù)。
- SET IDENTITY_INSERT 表名 OFF:表示關(guān)閉對標(biāo)識列顯示值的插入操作,標(biāo)識列不允許手動插入顯示值。
注意:IDENTITY_INSERT的開啟ON和關(guān)閉OFF是成對出現(xiàn)的,所以,在執(zhí)行完手動插入操作之后,記得一定要把IDENTITY_INSERT設(shè)置為OFF,否則下次的自動插入數(shù)據(jù)會插入失敗。
例如:
創(chuàng)建一張表b1,b_id為標(biāo)識列,設(shè)置為唯一標(biāo)識,從1開始,每次插入新數(shù)據(jù)時,值都遞增1,不允許為空:
CREATE table b1 ( b_id int identity(1,1) primary key not null, b_name varchar(20) null )
當(dāng)把表b1中b_id這一列設(shè)置為唯一標(biāo)識列的時候,IDENTITY_INSERT屬性的值就默認被設(shè)置為了OFF了。標(biāo)識列b_id列不允許手動去插入顯示值,只能由系統(tǒng)自動按照排順序去插入顯示的值。
1.當(dāng)IDENTITY_INSERT 為OFF時,往表b1中插入2條數(shù)據(jù),往標(biāo)識列中手動插入顯示值:
代碼1:
insert into b1(b_id,b_name) values(1,'莉莉') insert into b1(b_id,b_name) values(2,'阿呆')
插入結(jié)果:
代碼2:
insert into b1(b_name) values('莉莉') insert into b1(b_name) values('阿呆')
插入結(jié)果:
說明:當(dāng)把IDENTITY_INSERT設(shè)置為OFF時,標(biāo)識列是不允許手動插入顯示值的,只能有系統(tǒng)去自動插入標(biāo)識列的顯示值。
2.當(dāng)IDENTITY_INSERT 為ON時,往表b1中插入2條數(shù)據(jù),往標(biāo)識列中手動插入顯示值:
代碼1:
set identity_insert b1 on --開啟對標(biāo)識列的插入模式,標(biāo)識列允許手動插入顯示值 insert into b1(b_id,b_name) values(8,'小白') --手動去插入標(biāo)識列b_id的顯示值為8 insert into b1(b_id,b_name) values(9,'小黑') set identity_insert b1 off --關(guān)閉對標(biāo)識列的插入操作,標(biāo)識列不允許手動插入顯示值
插入結(jié)果:
代碼2:
set identity_insert b1 on --開啟對標(biāo)識列的插入模式,標(biāo)識列允許手動插入顯示值 insert into b1(b_name) values('小胖') --手動去插入標(biāo)識列b_id的顯示值為8 insert into b1(b_name) values('小寶') set identity_insert b1 off --關(guān)閉對標(biāo)識列的插入操作,標(biāo)識列不允許手動插入顯示值
插入結(jié)果:
說明:當(dāng)設(shè)置IDENTITY_INSERT為ON時,必須要指定標(biāo)識列中要插入的的顯示值,要手動的插入標(biāo)識列中的顯示值。因為系統(tǒng)將不再對標(biāo)識列的顯示值自動插入了。所以,必須要手動去給標(biāo)識列插入顯示值。
到此這篇關(guān)于SQL IDENTITY_INSERT作用案例詳解的文章就介紹到這了,更多相關(guān)SQL IDENTITY_INSERT作用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL制作具有千萬條測試數(shù)據(jù)的測試庫的方法
這篇文章主要介紹了MySQL制作具有千萬條測試數(shù)據(jù)的測試庫的方法,幫助大家更好的理解和學(xué)習(xí)MySQL,感興趣的朋友可以了解下2020-11-11使用Memcache緩存mysql數(shù)據(jù)庫操作的原理和緩存過程淺析
這篇文章主要介紹了使用Memcache緩存mysql數(shù)據(jù)庫操作的原理和緩存過程淺析,本文著重點在Memcache和MySQL數(shù)據(jù)庫的交互過程及流程分解,需要的朋友可以參考下2014-07-07MySql 存儲引擎和索引相關(guān)知識總結(jié)
這篇文章主要介紹了MySql 存儲引擎和索引相關(guān)知識總結(jié),文中講解非常細致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-06-06MySQL數(shù)據(jù)庫配置信息查看與修改方法詳解
我們通常把在項目中使用的常量收集在一個文件,這個文件就是配置文件,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫配置信息查看與修改的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-06-06windows環(huán)境中mysql忘記root密碼的解決方法詳解
本篇文章是對windows環(huán)境中mysql忘記root密碼的解決方法進行了詳細的分析介紹,需要的朋友參考下2013-06-06