在進行數(shù)據(jù)插入時,如果插入列名包括標識列,常常會遇到以下3種提示:
一、“當(dāng) IDENTITY_INSERT 設(shè)置為 OFF 時,不能向表 'xxxxxxxx' 中的標識列插入顯式值!
示例:
1.首先建立一個有標識列的表:
CREATE TABLE products (id int IDENTITY PRIMARY KEY, product varchar(40))
2.嘗試在表中做以下操作:
INSERT INTO products (id, product) VALUES(3, 'garden shovel')
結(jié)果會導(dǎo)致錯誤:“當(dāng) IDENTITY_INSERT 設(shè)置為 OFF 時,不能向表 'products' 中的標識列插入顯式值!
3.改用:
SET IDENTITY_INSERT products ON
INSERT INTO products (id, product) VALUES(1, 'garden shovel')
返回正確。
二、:“表 'DBName.dbo.TableName1' 的 IDENTITY_INSERT 已經(jīng)為 ON。無法對表 'TableName2' 執(zhí)行 SET 操作!
4.建立另外一個表products2,嘗試相同插入操作:
CREATE TABLE products2 (id int IDENTITY PRIMARY KEY, product varchar(40))
然后執(zhí)行:
SET IDENTITY_INSERT products2 ON
INSERT INTO products2 (id, product) VALUES(1, 'garden shovel')
導(dǎo)致錯誤:“表 'material.dbo.products' 的 IDENTITY_INSERT 已經(jīng)為 ON。無法對表 'products2' 執(zhí)行 SET 操作!
改為執(zhí)行:
SET IDENTITY_INSERT products OFF
SET IDENTITY_INSERT products2 ON
INSERT INTO products2 (id, product) VALUES(2, 'garden shovel')
執(zhí)行通過。
三、“僅當(dāng)使用了列的列表,并且 IDENTITY_INSERT 為 ON 時,才能在表 'TableName' 中為標識列指定顯式值!
5.嘗試以下操作:
SET IDENTITY_INSERT products2 ON
INSERT INTO products2 SELECT * FROM products
導(dǎo)致錯誤:“僅當(dāng)使用了列的列表,并且 IDENTITY_INSERT 為 ON 時,才能在表 'products2' 中為標識列指定顯式值!
6.改為:
SET IDENTITY_INSERT products2 ON
INSERT INTO products2 (id, product) SELECT * FROM products
執(zhí)行通過。
總結(jié):
1、要對數(shù)據(jù)表的標識列執(zhí)行插入操作進,先要設(shè)置該數(shù)據(jù)表identity_insert為on;同時要列出些標識列(當(dāng)然,同時也就需要列出相關(guān)的其他列了)。
2、每一次連接會話中的任一時刻,只能對一個表設(shè)置IDENTITY_INSERT ON,且設(shè)置只對當(dāng)前會話有效