程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> 更多數據庫知識 >> sqlsever為標識列指定顯式值

sqlsever為標識列指定顯式值

編輯:更多數據庫知識

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為標識列指定顯式值總結到此結束,如有疑問請聯系我們www.cncnc.com.cn,中國信息港為你提供高效安全的sql數據庫。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved