おすすめ記事

同じカテゴリー

コンボボックスに重複しないデータを表示する



Accessでコンボボックスを使用して抽出する方法はいくつかありますが、テーブル内の重複しないデータをコンボボックスに表示する方法を紹介します。
下のようなテーブルがあります。[T_担当一覧]テーブルとしています。
テーブル

[会社名]コンボボックスに[会社名]の重複しないリスト一覧が表示されるよう設定します。
コンボボックス


まず、クエリを作成します。テーブル[T_担当一覧]を表示して、フィールド[会社名]をドラッグします。
queryの作成

スポンサーリンク

クエリで右クリックして、ショートカットメニューから[プロパティ]をクリックします。
ショートカットメニュー

クエリプロパティの[固定の値]を[はい]にします。
クエリプロパティ

クエリを実行してみます。会社名の重複しないデータが表示されます。クエリは[Q_会社名]として保存します。
クエリの実行

同じように[部署]も重複しないデータが表示されるクエリを作成します。[Q_部署]として保存します。


また、このクエリの作り方は、SQLビューを表示して[DISTINCT]を入力してもいいです。クエリプロパティの固有の値を[はい]にするか、SQLビューで入力するか、どちらかを設定してください。
SQLビューは、クエリを右クリックして[SQLビュー]をクリックします。
SQLビューの選択
または、表示ボタンから切り替えます。
表示ボタンから切り替え
SELECTの後に[半角スペース][DISTINCT][半角スペース]を入力します。[DISTINCT]は半角です。
SQLビュー

クエリの準備ができたら、フォームを作成します。[T_担当一覧]テーブルを元に分割フォームを作成します。
分割フォームの作成

非連結のコンボボックスを2個作成します。
非連結のコンボボックスを作成

コンボボックスは、ウィザードを使用してもいいですが、テキストボックスを作成した後、右クリックのショートカットメニューから[コントロールの種類の変更]をポイントして[コンボボックス]をクリックしてもいいです。コンボボックスは、[会社名コンボ]と[部署コンボ]という名前を付けます。
コントロールの種類の変更


[会社名コンボ]のプロパティを表示して、値集合ソースに[Q_会社名]を指定します。
値集合ソースに[Q_会社名]を指定

また、[部署コンボ]には、フォームの[会社名]で絞り込んだ値を表示したいので、[Q_部署]クエリを下のように編集します。
クエリの編集

[部署コンボ]の値集合ソースには、[Q_部署]を指定します。
値集合ソースには、[Q_部署]を指定

フォームビューに切り替えて、会社名を選択すると、部署は絞り込んだリストが表示されます。
フォームビューのコンボ

フォームのコンボボックスの設定はできたので、このコンボで抽出できるように設定します。[会社名コンボ]の[更新後処理]で下のように書き込みます。再クエリも忘れないように入力します。[部署]コンボの[更新後処理]では、[会社名]と[部署]の複数条件でフィルタリングします。
更新後処理のイベントプロシージャ

フォームビューに切り替えて、絞り込んだ値のみが表示されることを確認します。
フォームビューで確認

[フィルター解除]ボタンも設置するといいかもしれません。ボタンを作成して、クリック時イベントに下のように書くといいです。
Me.FilterOn = False

詳細は、コンボボックスでレコードの抽出のページを参照してください。
フィルター解除ボタン

重複しないデータの個数を求める方法も紹介しています。

トラブルをすぐに解決したいならteratail

おすすめ記事

シェアする