CRecordset クラス
データ ソースから選択された 1 組のレコードセットを表現します。
class CRecordset : public CObject
解説
「レコード セット」として、知られているCRecordsetオブジェクトが使用される 2 つの形式。ダイナセットとスナップショット。 ダイナセットは、ほかのユーザーによる更新との同期をとります。 スナップショットはデータの静的なビューです。 どちらの形式もレコードセットを開いた時点では固定のレコードの組み合わせを表しますが、ダイナセットでレコードをスクロールすると、ほかのユーザーや同一のアプリケーションのほかのレコードセットが行った変更がレコードに反映されます。
注意
ODBC (Open Database Connectivity) クラスではなく、DAO (Data Access Objects) クラスを使用して作業する場合は、代わりに CDaoRecordset クラスを使用します。 詳細についてを参照してください「概要:データベース プログラミング。
どちらのレコードセットを使うにしても、アプリケーション固有のレコードセット クラスを CRecordset から派生する必要があります。 レコードセットはデータ ソースからレコードを選択します。レコードセットを使って次のことができます。
レコード間のスクロール。
レコードの更新とロック モードの指定。
データ ソースで利用できるレコードからどのレコードを選択するかを制限するためのレコードセットのフィルター。
レコードセットの並べ替え。
レコードセットをパラメーター化し、実行時までは不明な情報を使用して選択をカスタマイズします。
派生したクラスを使うには、データベースを開き、CDatabase オブジェクトへのポインターをコンストラクターに渡してレコードセット オブジェクトを作成します。 その後、ダイナセットかスナップショットかを指定して、レコードセットの Open メンバー関数を呼び出します。 呼び出された Open 関数は、データ ソースからデータを選択します。 レコードセット オブジェクトを開いた後、メンバー関数とデータ メンバーを使用して、レコードをスクロールし、操作します。レコードをスクロールし操作するには、オブジェクトのメンバー関数やデータ メンバーを使います。 利用できる操作は、オブジェクトがダイナセットかスナップショットか、更新可能か読み込み専用かによって決まります。オブジェクトが更新可能か読み込み専用かは、ODBC (Open Database Connectivity) データ ソースの能力と、バルク行フェッチを実装したかどうかに依存します。 Open 関数を呼び出した後の変更や追加を再表示するには Requery メンバー関数を呼び出します。 レコードセットを使用した作業を終了するときはオブジェクトの Close メンバー関数を呼び出し、オブジェクトを破棄します。
CRecordset の派生クラスでは、RFX (レコード フィールド エクスチェンジ) または Bulk RFX (バルク レコード フィールド エクスチェンジ) を利用して、レコード フィールドの読み込みや更新をサポートします。
レコード セットとレコード フィールド エクス チェンジの詳細についてを参照してください概要:データベース プログラミング、 レコード セット (ODBC)、 レコード セット:一括 (ODBC) 内のレコードをフェッチ、および レコード フィールド エクス (チェンジ RFX)。 ダイナセットとスナップショットについての重点的な解説は、「ダイナセット」と「スナップショット」を参照してください。
必要条件
**ヘッダー:**afxdb.h