PRB: 錯誤 」 INSERT 失敗 」 何時更新索引檢視表中所參考的資料表

文章翻譯 文章翻譯
文章編號: 305333 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

徵狀

當您執行預存程序或 SQL INSERT 陳述式直接,以嘗試插入索引檢視表中參考的資料表中的資料列,可能會發生下列錯誤:
INSERT 失敗,因為下列的 SET 選項具有不正確的設定值: 'ARITHABORT'
此外,即使 SET ARITHABORT ON"包含在批次或嘗試在 INSERT 的預存程序中,可能會發生這個錯誤。

發生的原因

若要成功地將資料列插入索引檢視表中參考的資料表,SQL ARITHABORT 組態設定必須設定為 ON。此外,套用此組態設定陳述式必須執行它自己的批次中。由於預存程序包含只有一個批次,將陳述式加入至程序無法運作。

解決方案

如果要解決這個問題,加入下列程式 ADO 碼至您的應用程式在您開啟連線到您的資料庫後:
MyConnection.Execute "SET ARITHABORT ON"
				
MyConnection 位置是 ADO 連接物件,您用來執行預存程序執行一個 INSERT 或 SQL INSERT 陳述式的參考。

狀況說明

這種行為是經過設計規劃的。

其他相關資訊

SET ARITHABORT ON 是其中一個會不會自動設為 SQL Server 或 SQL Server ODBC 驅動程式使用 OLE DB 提供者的連線的選項。因為 ARITHABORT 設定、 連線預設為伺服器預設值是 ARITHABORT OFF,請勿指定 OLE DB 與 ODBC 連線。

?考

如需詳細資訊請參閱 SQL Server 2000 線上叢書 》 中 < 設計的索引檢視"] 和 [建立的索引 」 主題]。

屬性

文章編號: 305333 - 上次校閱: 2003年5月8日 - 版次: 2.2
這篇文章中的資訊適用於:
  • Microsoft ActiveX Data Objects 2.6?應用於:
    • Microsoft SQL Server 2000 Standard Edition
  • Microsoft ActiveX Data Objects 2.7?應用於:
    • Microsoft SQL Server 2000 Standard Edition
關鍵字:?
kbmt kbprb KB305333 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:305333
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com