方法: Windows フォーム BindingSource コンポーネントを使用してルックアップ テーブルを作成する
ルックアップ テーブルは、関連するテーブル内のレコードのデータを表示する列を持つ、データ テーブルです。 以下の手順では、ComboBox コントロールを使用して、親テーブルから子テーブルへの外部キー リレーションシップを持つフィールドを表示します。
これらの 2 つのテーブルとこの関係をわかりやすく視覚化するために、親テーブルと子テーブルの例を次に示します。
CustomersTable (親テーブル)
CustomerID | CustomerName |
---|---|
712 | Paul Koch |
713 | Tamara Johnston |
OrdersTable (子テーブル)
OrderID | OrderDate | CustomerID |
---|---|---|
903 | February 12, 2004 | 712 |
904 | February 13, 2004 | 713 |
このシナリオでは、一方のテーブル (CustomersTable) に、表示および保存する実際の情報を格納します。 ただし領域を節約するために、このテーブルには情報を明確化するデータは含まれていません。 もう一方のテーブル (OrdersTable) には、どの顧客 ID 番号がどの発注日および発注 ID に相当するか、について表示関連の情報のみが格納されます。 顧客名の記述は含まれません。
ルックアップ テーブルを作成するには、ComboBox コントロールで次の 4 つの重要なプロパティを設定します。
DataSource プロパティには、テーブルの名前が格納されます。
DisplayMember プロパティには、コントロール テキスト (顧客名) に対して表示する、テーブルのデータ列が格納されます。
ValueMember プロパティには、格納された情報 (親テーブルの ID 番号) を持つ、テーブルのデータ列が格納されます。
SelectedValue プロパティは、ValueMember に基づいて子テーブルのルックアップ値を提供します。
以下の手順では、フォームをルックアップ テーブルとしてレイアウトし、フォームのコントロールにデータをバインドする方法を示します。 この手順を完了するには、データ ソース、および前述の外部キー リレーションシップを持つ親テーブルと子テーブルから構成されるデータ ソースが必要です。
ユーザー インターフェイスを作成するには
ツールボックスから、ComboBox コントロールをフォームにドラッグします。
このコントロールは、親テーブルの列を表示します。
子テーブルの詳細を表示する他のコントロールをドラッグします。 テーブル内のデータの形式によって、選択するコントロールが決まります。 詳細については、「Windows フォーム コントロールの機能別一覧」を参照してください。
BindingNavigator コントロールをフォームにドラッグします。これにより、子テーブル内のデータを移動できるようになります。
データに接続し、コントロールにバインドするには
ComboBox を選択し、スマート タスク グリフをクリックして [スマート タスク] ダイアログ ボックスを表示します。
[データ バインド項目を使用する] を選択します。
[データ ソース] ドロップダウン ボックスの横の矢印をクリックします。 プロジェクトまたはフォームに対してデータ ソースがすでに構成されている場合はデータ ソースが表示されますが、設定されていない場合は、次の手順を実行します (この例では、Northwind サンプル データベースの Customers テーブルと Orders テーブルを使用します。これらのテーブルについては括弧の中で参照します)。
[プロジェクト データ ソースの追加] をクリックしてデータに接続し、データ ソースを作成します。
データ ソース構成ウィザードの開始ページで [次へ] をクリックします。
[データソースの種類を選択] ページで、[データベース] をクリックします。
[データ接続の選択] ページの利用可能な接続の一覧から、データ接続を選択します。 目的のデータ接続を選択できない場合は、[新しい接続] を選択して新しいデータ接続を作成します。
[次の名前で接続を保存する] をオンにして、接続文字列をアプリケーション構成ファイルに保存します。
アプリケーションで使用するデータベース オブジェクトを選択します。 この場合、外部キー リレーションシップを持つ親テーブルと子テーブル (Customers と Orders など) を選択します。
必要な場合は、既定のデータセット名を変更します。
[Finish] をクリックします。
[表示メンバー] ドロップダウン ボックスで、コンボ ボックスに表示する列名 (ContactName など) を選択します。
[値メンバー] ドロップダウン ボックスで、子テーブルでルックアップ操作を実行する列 (CustomerID など) を選択します。
[選択された値] ドロップダウン ボックスで [プロジェクト データ ソース] に移動し、親テーブルと子テーブルを含む、作成したばかりのデータセットに移動します。 親テーブルの Value Member に対応する、子テーブルのプロパティ (Orders.CustomerID など) を選択します。 適切な BindingSource、データ セット、およびテーブル アダプタ コンポーネントが作成され、フォームに追加されます。
BindingNavigator コントロールを子テーブルの BindingSource (
OrdersBindingSource
など) にバインドします。ComboBox および BindingNavigator コントロール以外のコントロールを、表示する子テーブルの BindingSource (
OrdersBindingSource
など) の詳細フィールドにバインドします。
関連項目
.NET Desktop feedback