資料錄集:資料錄集選取資料錄的方式 (ODBC)

本文件適用於 MFC ODBC 類別。

這個主題說明:

  • 您在選取資料錄時的角色和選項。

  • 資料錄集建構其 SQL 陳述式和選取資料錄的方式。

  • 自訂選取的方式。

資料錄集藉由將 SQL 陳述式送至 ODBC 驅動程式,透過驅動程式選取資料來源中的資料錄。 送出的 SQL 將根據您設計和開啟資料錄集類別的方式,而有所不同。

選取資料錄時的選項

下表說明您在選取資料錄時的選項。

您如何及何時可影響資料錄集

當您

您可以

使用 [加入類別] 精靈來宣告您的資料錄集類別

指定進行選取的資料表。

指定要包括哪些資料行。

請參閱加入 MFC ODBC 消費者

完成您的資料錄集類別實作

覆寫例如 OnSetOptions (進階的) 等成員函式來設定特定應用程式選項或變更為預設值。 若您想要一個參數型的資料錄集,則指定參數資料成員。

建構資料錄集物件 (在您呼叫 Open 之前)

WHERE 子句內指定一個搜尋條件 (可能是複合的),以便用來篩選資料錄。 請參閱資料錄集:篩選資料錄 (ODBC)

ORDER BY 子句內指定一個排序順序,以便排序資料錄。 請參閱資料錄集:排序資料錄 (ODBC)

為任何您加到類別中的參數指定參數值。 請參閱資料錄集:參數化資料錄集 (ODBC)

呼叫 Open 來執行資料錄集的查詢

指定自訂的 SQL 字串來取代精靈所設定的預設 SQL 字串。 請參閱《類別庫參考》內的 CRecordset::OpenSQL:自訂資料錄集的 SQL 陳述式 (ODBC)

呼叫 Requery,使用資料來源上的最新值來重新查詢資料錄集

指定新的參數、篩選條件或排序。 請參閱資料錄集:重新查詢資料錄集 (ODBC)

資料錄集建構其 SQL 陳述式的方式

當您呼叫資料錄集物件的 Open 成員函式時,Open 會使用下列某些或所有因素來建構 SQL 陳述式:

  • 傳遞至 OpenlpszSQL 參數。 若不是 NULL,此參數便會指定自訂的 SQL 字串或字串的一部分。 架構會剖析此字串。 若該字串是一個 SQL SELECT 陳述式或一個 ODBC CALL 陳述式,架構會使用該字串做為資料錄集的 SQL 陳述式。 若該字串不是以 "SELECT" 或 "{CALL" 開頭,架構會使用所提供的項目來建構 SQL FROM 子句。

  • GetDefaultSQL 傳回的字串。 預設情形下,這會是您在精靈中指定給資料錄集的資料表名稱,但您可變更此函式傳回的字串。 架構會呼叫 GetDefaultSQL,如果該字串不是以 "SELECT" 或 "{CALL" 開頭,它會假設該字串為用來建構 SQL 字串的資料表名稱。

  • 資料錄集的欄位資料成員,此成員是用來繫結資料表內特定的資料行。 架構會將資料錄資料行繫結至這些成員的位置,把它們當做緩衝區使用。 架構會從資料錄集的 DoFieldExchangeDoBulkFieldExchange 成員函式內的 RFX 或 Bulk RFX 函式呼叫,來決定欄位資料成員與資料表資料行間的相互關聯。

  • 資料錄集的篩選條件 (如果有的話) 會包含在 m_strFilter 資料成員內。 架構會使用此字串來建構 SQL WHERE 子句。

  • 資料錄集的排序順序 (如果有的話) 會包含在 m_strSort 資料成員內。 架構會使用此字串來建構 SQL ORDER BY 子句。

    秘訣秘訣

    若要使用 SQL GROUP BY 子句 (可能是 HAVING 子句),請將該子句附加至您的篩選字串結尾。

  • 您為該類別所指定的任何參數資料成員值。 您只能在呼叫 OpenRequery 前設定參數值。 架構會將參數值繫結至 SQL 字串內的 "?" 替代符號。 您可以在編譯時間中,使用替代符號來指定該字串。 在執行階段時,架構會根據您傳入的參數值來填入詳細資訊。

Open 會從這些因素來建構 SQL SELECT 陳述式。 如需架構如何使用這些因素的詳細資訊,請參閱自訂選取。

在建構陳述式後,Open 會將此 SQL 傳送至 ODBC 驅動程式管理員 (如果 ODBC 資料指標程式庫還在記憶體中的話),它會將 SQL 傳給特定 DBMS 的 ODBC 驅動程式。 驅動程式會與 DBMS 溝通,完成資料來源上的選取,並擷取第一筆資料錄。 架構會將資料錄載入資料錄集的欄位資料成員中。

您可使用這些技術的組合來開啟資料表,並根據多個資料表的聯結來建構查詢。 有了其他的自訂項目,您可以呼叫預先定義查詢 (預存程序)、選取設計階段時未知的資料表資料行,以及將它們繫結至資料錄集欄位,或執行大多數其他的資料存取工作。 您不能自訂資料錄集來完成的工作仍可藉由呼叫 ODBC API 函式,或直接使用 CDatabase::ExecuteSQL 執行 SQL 陳述式來完成。

自訂選取

您除了可以提供篩選條件、排序順序或參數外,還可採取下列動作來自訂您的資料錄集選取:

  • 當為資料錄集呼叫 Open 時,請在 lpszSQL 內傳遞自訂的 SQL 字串。 您在 lpsqSQL 內傳遞的任何字串都會比 GetDefaultSQL 成員函式所傳回的還要優先。

    如需詳細資訊,請參閱 SQL:自訂資料錄集的 SQL 陳述式 (ODBC),會說明您可以傳遞至 Open 的 SQL 陳述式類型 (或部分陳述式),以及架構能使用這些類型所做的事。

    注意事項注意事項

    若您所傳入的自訂字串不是以 "SELECT" 或 "{CALL" 開頭,MFC 會假設字串包含有資料表名稱。 這也適用於下一個項目符號項目。

  • 改變精靈在資料錄集的 GetDefaultSQL 成員函式中編寫的字串。 編輯函式的程式碼以變更傳回的字串。 預設地,精靈會編寫一個傳回單一資料表名稱的 GetDefaultSQL 函式。

    您可讓 GetDefaultSQL 傳回任何您傳給 OpenlpszSQL 參數。 如果沒有在 lpszSQL 內傳遞自訂的 SQL 字串,架構會使用 GetDefaultSQL 傳回的字串。 GetDefaultSQL 至少必須傳回單一資料表名稱。 但您可讓它傳回多個資料表名稱、一個完整的 SELECT 陳述式、一個 ODBC CALL 陳述式等等。 如需可以傳遞什麼內容至 lpszSQL 或可以讓 GetDefaultSQL 傳回什麼內容的清單,請參閱 SQL:自訂資料錄集的 SQL 陳述式 (ODBC)

    若您正在執行兩個或多個資料表的聯結,請改寫 GetDefaultSQL 以自訂用於 SQL FROM 子句的資料表清單。 如需詳細資訊,請參閱資料錄集:執行聯結 (ODBC)

  • 手動繫結附加的欄位資料成員,也許是根據您在執行階段所取得的資料來源結構描述資料進行繫結。 您加入欄位資料成員至資料錄集類別、在 DoFieldExchangeDoBulkFieldExchange 成員函式內加入 RFX 或 Bulk RFX 函式呼叫,以及類別建構函式 (Constructor) 內資料成員的初始化。 如需詳細資訊,請參閱資料錄集:動態地繫結資料行 (ODBC)

  • 覆寫例如 OnSetOptions 的資料錄集成員函式,以設定特定應用程式選項或覆寫預設值。

如果您想要根據複雜的 SQL 陳述式來建構資料錄集,會需要使用這些自訂技術的某些組合。 例如,也許您想要使用資料錄集無法直接支援的 SQL 子句和關鍵字,或是正在聯結多個資料表。

請參閱

概念

資料錄集 (ODBC)

資料錄集:資料錄集更新資料錄的方式 (ODBC)

ODBC 的基本概念

SQL

資料錄集:鎖定資料錄 (ODBC)