sqlsever為標(biāo)識(shí)列指定顯式值

僅當(dāng)使用了列列表并且 IDENTITY_INSERT 為 ON 時(shí),才能為表’*’中的標(biāo)識(shí)列指定顯式值

sqlsever為標(biāo)識(shí)列指定顯式值的問題,大多是大家在兩個(gè)結(jié)構(gòu)完全相同的表,由其中一個(gè)表插入另一個(gè)表中指定條件的數(shù)據(jù),報(bào)如下錯(cuò)誤:
僅當(dāng)使用了列列表并且 IDENTITY_INSERT 為 ON 時(shí),才能為表’*’中的標(biāo)識(shí)列指定顯式值。
在網(wǎng)上找到了解決方案,親自試過,可以解決。
一、問題詳述如下:
系統(tǒng):
數(shù)據(jù)庫(kù):2005
數(shù)據(jù)庫(kù)實(shí)例:wzgl2004 和wzgl2003,這兩個(gè)實(shí)例都有表kc
執(zhí)行語(yǔ)句
insert into wzgl2004.dbo.kc select * from wzgl2003.dbo.kc
就有報(bào)錯(cuò)信息:
“僅當(dāng)使用了列的列表,并且 IDENTITY_INSERT 為 ON 時(shí),才能在表 ‘wzgl2004.dbo.kc ‘ 中為標(biāo)識(shí)列指定顯式值。”

二、解決方法
代碼如下:
SET IDENTITY_INSERT test ON
insert into wzgl2004.dbo.kc(id,name) select (id,name) from wzgl2003.dbo.kc
SET IDENTITY_INSERT test OFF

三、SET IDENTITY_INSERT的幫助知識(shí)
1、SET IDENTITY_INSERT :允許將顯式值插入表的標(biāo)識(shí)列中。
2、語(yǔ)法
SET IDENTITY_INSERT [ database.[ owner.] ] { table } { ON | OFF }
參數(shù)
database
是指定的表所駐留的數(shù)據(jù)庫(kù)名稱。
owner
是表所有者的名稱。
table
是含有標(biāo)識(shí)列的表名。

3、附加:任何時(shí)候,會(huì)話中只有一個(gè)表的 IDENTITY_INSERT 屬性可以設(shè)置為 ON。如果某個(gè)表已將此屬性設(shè)置為 ON,并且為另一個(gè)表發(fā)出了 SET IDENTITY_INSERT ON 語(yǔ)句,則 Microsoft? SQL Server? 返回一個(gè)錯(cuò)誤信息,指出 SET IDENTITY_INSERT 已設(shè)置為 ON 并報(bào)告此屬性已設(shè)置為 ON 的表。 如果插入值大于表的當(dāng)前標(biāo)識(shí)值,則 SQL Server 自動(dòng)將新插入值作為當(dāng)前標(biāo)識(shí)值使用。
SET IDENTITY_INSERT 的設(shè)置是在執(zhí)行或運(yùn)行時(shí)設(shè)置,而不是在分析時(shí)設(shè)置。
sqlsever為標(biāo)識(shí)列指定顯式值總結(jié)到此結(jié)束,如有疑問請(qǐng)聯(lián)系我們www.cncnc.com.cn,中國(guó)信息港為你提供高效安全的sql數(shù)據(jù)庫(kù)。

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊11 分享