共用方式為


交易 (ODBC)

本文件適用於 MFC ODBC 類別。

交易是對資料來源以群組或批次一系列更新的方法,使得所有更新一次認可,或在您復原交易時不認可任何更新。 如果您不使用交易,資料來源的變動將會自動地認可,而非視需求來認可。

注意事項注意事項

不是所有的 ODBC 資料庫驅動程式都支援交易。您可呼叫 CDatabaseCRecordset 物件的 CanTransact 成員函式,以決定驅動程式是否支援指定資料庫的交易。請注意,CanTransact 並不會告訴您資料來源是否提供完整的交易支援。您同時必須在 CommitTransRollback 後呼叫 CDatabase::GetCursorCommitBehaviorCDatabase::GetCursorRollbackBehavior 以檢查所開啟的 CRecordset 物件之交易效果。

對於 CRecordset 物件的 AddNewEdit 成員函式的呼叫將會在呼叫 Update 時立即影響資料來源。 Delete 呼叫也會立即生效。 反之,您可使用一筆包含多個呼叫 AddNewEditUpdateDelete 的交易,它雖會執行但卻不認可直到您明確地呼叫 CommitTrans 為止。 藉由建立交易,您可執行一系列這種呼叫卻仍能保留將其復原的能力。 若一個重要的資源已不適用或某些其他的情況造成整個交易不能完成,您可復原此交易而不用認可它。 在這種情況下,交易所做的所有變更將不會影響資料來源。

注意事項注意事項

目前,如果您實作大量資料列擷取 (Bulk Row Fetching),CRecordset 類別並不支援資料來源的更新。這意謂您不能呼叫 AddNewEditDeleteUpdate。然而,您可撰寫您自己的函式來執行更新,並在給予的交易下呼叫這些函式。如需關於大量資料列擷取的詳細資訊,請參閱資料錄集:擷取大量資料錄 (ODBC)

注意事項注意事項

除了影響您的資料錄集 (Recordset) 以外,只要您使用與 CDatabase 物件相關的 ODBC HDBC 或依據此 HDBC 的 ODBC HSTMT,交易就會影響您直接執行的 SQL 陳述式 (Statement)。

當您需要同時更新多重資料錄時,交易尤其有用。 在這種情況下,您想要避免交易只完成一半,例如若在完成最後更新之前擲回例外狀況 (Exception),就可能會發生。 將這樣的更新群組成一筆交易將允許從變更中復原,並使得資料錄回到尚未交易的狀態。 例如,若一間銀行將錢由 A 帳戶轉帳到 B 帳戶,從 A 提錢和存錢至 B 都必須成功才能正確地處理存款,否則整筆交易必定會失敗。

在資料庫類別中,您是透過 CDatabase 物件來執行交易。 一個 CDatabase 物件代表對一個資料來源的連接,而一或多個和 CDatabase 物件相關的資料錄集是透過資料錄集成員函式在資料庫內的資料表上作業。

注意事項注意事項

只支援一個層級的交易。您不能使用巢狀交易,也無法將一筆交易擴展成多個資料庫物件。

下列主題提供如何執行交易的詳細資訊:

請參閱

概念

開放式資料庫連接 (ODBC)