新規レコードの追加
データの変更 への移動
データセットは、アプリケーションが新しいレコードを追加する前に、dsInsert モードになっていなければなりません。コードでは、Insert または Append メソッドを使用して、データセットを dsInsert モードにすることができます(データセットの読み取り専用 CanModify プロパティが True の場合)。
データセットが dsInsert モードへ移ると、まず BeforeInsert イベントを受信します。挿入モードへの遷移が正常に終わると、データセットはまず OnNewRecord イベントを、次に AfterInsert イベントを受け取ります。これらのイベントは、たとえば、初期値を新たに挿入されたレコードに提供するために、使用できます:
procedure TForm1.OrdersTableNewRecord(DataSet: TDataSet);
begin
DataSet.FieldByName('OrderDate').AsDateTime := Date;
end;
void __fastcall TForm1::OrdersTableNewRecord(TDataSet *DataSet)
{
DataSet->FieldByName("OrderDate")->AsDateTime = Date();
}
アプリケーションのフォーム上では、データ対応グリッドおよびナビゲータのコントロールが、データセットを dsInsert 状態に設定できますが、それは次の場合です:
- コントロールの ReadOnly プロパティが False(デフォルト)、かつ
- データセットの CanModify が True
メモ: データセットが dsInsert 状態であっても、アプリケーションのユーザーが適切な SQL アクセス権限を持っていない場合、SQL ベースのデータベースに対するレコードの追加は成功しません。
データセットが dsInsert モードになったら、ユーザーまたはアプリケーションは、その新しいレコードに関連づけられたフィールドに、値を入力することができます。グリッドおよびナビゲータのコントロールを除き、ユーザーには、Insert と Append に違いは見られません。Insert への呼び出し時、グリッドにおいて、現在のレコードの上に空の行が現れます。Append への呼び出し時、グリッドはデータセットの最後のレコードにスクロールされ、空の行がグリッドの一番下にに現れ、Next および Last ボタンが、データセットに関連づけられているナビゲータ コンポーネント上では、淡色表示になります。
挿入が有効になるデータ対応コントロールは、ユーザーが現在のレコードを変更するようななんらかのアクション(グリッド内で別のレコードに移動するなど)を実行すると、Post を自動的に呼び出します。そうでなければ、コードで Post を呼び出さなければなりません。
Post はデータベースに新しいレコードを書き込むか、更新をキャッシュしている場合には、Post はメモリ内のキャッシュにレコードを書き込みます。キャッシュされた挿入を書き込み、データベースへ追加するには、データセットの ApplyUpdates メソッドを呼び出します。
レコードを挿入する
Insert は、新しい空のレコードを、現在のレコードの前に開き、その空のレコードを現在のレコードにして、レコードのフィールド値が、ユーザーまたはアプリケーション コードによってそこに入力されるようにします。
アプリケーションが Post(または、キャッシュされた更新を使用している場合には ApplyUpdates)を呼び出すと、新たに挿入されたレコードが次の 3 つのいずれかの方法で、データベースに書き込まれます。
- インデックス付きのテーブル Paradox と dBASE の場合、レコードは、そのインデックスに基づいた位置でデータセットに挿入されます。
- インデックスなしのテーブル Paradox と dBASE の場合、レコードは現在の位置でデータセットに挿入されます。
- SQL データベースの場合、挿入の物理的な位置は、実装固有です。テーブルがインデックス付きだったら、新しいレコードの情報でインデックスは更新されます。
レコードを追加する
Append は、新しい空のレコードを、データセットの最後に開き、その空のレコードを現在のレコードにして、レコードのフィールド値が、ユーザーまたはアプリケーション コードによってそこに入力されるようにします。
アプリケーションが Post(または、キャッシュされた更新を使用している場合には ApplyUpdates)を呼び出すと、新たに追加されたレコードが次の 3 つのいずれかの方法で、データベースに書き込まれます。
- インデックス付きのテーブル Paradox と dBASE の場合、レコードは、そのインデックスに基づいた位置でデータセットに挿入されます。
- インデックスなしのテーブル Paradox と dBASE の場合、レコードはデータセットの最後に追加されます。
- SQL データベースの場合、追加の物理的な位置は、実装固有です。 テーブルがインデックス付きだったら、新しいレコードの情報でインデックスは更新されます。