sqlsever為標識列指定顯式值的問題,大多是大家在兩個結構完全相同的表,由其中一個表插入另一個表中指定條件的數據,報如下錯誤: 僅當使用了列列表并且 IDENTITY_INSERT 為 ON 時,才能為表'*'中的標識列指定顯式值。 在網上找到了解決方案,親自試過,可以解決。 一、問題詳述如下: 系統:windows2003 數據庫:2005 數據庫實例:wzgl2004 和wzgl2003,這兩個實例都有表kc 執行語句 insert into wzgl2004.dbo.kc select * from wzgl2003.dbo.kc 就有報錯信息: "僅當使用了列的列表,并且 IDENTITY_INSERT 為 ON 時,才能在表 'wzgl2004.dbo.kc ' 中為標識列指定顯式值。"
二、解決方法:
復制代碼 代碼如下:
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的幫助知識 1、SET IDENTITY_INSERT :允許將顯式值插入表的標識列中。 2、語法 SET IDENTITY_INSERT [ database.[ owner.] ] { table } { ON | OFF } 參數 database 是指定的表所駐留的數據庫名稱。 owner 是表所有者的名稱。 table 是含有標識列的表名。
3、附加:任何時候,會話中只有一個表的 IDENTITY_INSERT 屬性可以設置為 ON。如果某個表已將此屬性設置為 ON,并且為另一個表發出了 SET IDENTITY_INSERT ON 語句,則 Microsoft® SQL Server™ 返回一個錯誤信息,指出 SET IDENTITY_INSERT 已設置為 ON 并報告此屬性已設置為 ON 的表。 如果插入值大于表的當前標識值,則 SQL Server 自動將新插入值作為當前標識值使用。 SET IDENTITY_INSERT 的設置是在執行或運行時設置,而不是在分析時設置。 sqlsever為標識列指定顯式值總結到此結束,如有疑問請聯系我們,中國信息港為你提供高效安全的sql數據庫。