MS Access

AccessでIN演算子をクエリの抽出条件に使うのに苦労

投稿日:

やりたいこと:

非連結のチェックボックスでレコードを選択する – hatena chips

・・・のようなこと。

・フォームのテキストボックスに、’354942-00074747′,’354942-00095716′,’354942-00057735’などのように、受注番号の検索キーワードがセットされるように、あらかじめVBAで作ってある。

・コマンドボタンをクリックすると、クエリの抽出条件に、上記のキーワードがIN演算子でセットされて、検索結果が返ってくる(この場合は3件)。

つまづいたこと:

しかし、うまくいかない。

最初、クエリの抽出条件欄に、
IN ([Forms]![楽天未発送].[txtChkList]) としたがダメで。

以下のようなユーザー関数を別途作って、

Public Function retOrderNo() As String
r = Replace([Forms]![楽天未発送].[txtChkList], ",", "','")
r = Mid(r, 3)
retOrderNo = r & "'"
'    Debug.Print r & "'"
End Function

クエリの抽出条件欄に、
In (RetOrderNO()) や “In (” & RetOrderNO() & “)” としたがやはりダメで。

色々調べていると、BuildCriteria関数を試してみると良さそうなので、使ってみた。
以下のページが参考になった。

パラメータクエリにIn演算子を用いて複数の条件で抽出するための設定 – もう一度学ぶMS-Access

初めてなので慣れていないかもだけど、この関数、イマイチ使い勝手がわからない。
最初、BuildCriteria関数を使いたくなくて、Eval関数だけでやろうとしたが、こんな感じで。
x: Eval([受注番号] In (retOrderNo()))
でも、やっぱりうまくいかない。

最終的には、以下のやり方でうまくいった。

z: Eval(BuildCriteria(“‘” & [受注番号] & “‘”,10,”In (” & retOrderNo() & “)”))

結果オーライだけども、
“‘”のシングルクォーテーションで囲む意味が分からない。
MSのページには、普通にダブルクォーテーションでフィールド名を囲んであったが、同じようにしたら「不明」っているダイアログでエラーが出てうまくいかなかった。

BuildCriteria メソッド (Access) | Microsoft Docs

-MS Access

執筆者:

関連記事

もう何度もAccessの集計クエリの作成をミスって怒られている

私が悪い。反省。 自戒のメモ。 Accessの集計クエリに条件を加えたい場合、その条件をどこに書くかによって結果が全く違ってくる。 それをわかってはいるのだが・・・最大やら演算やら、細かいことを同時に …

no image

VBAで英字混じりの引数から数字のみを取り出す関数

たとえば、abcABC123456XYGという引数から、123456のみを取り出したい。 VBAの組み込み関数で、適当なのがありそうだけど、無いみたい。 カスタム関数を作るにも、これはという情報がググ …

no image

AccessでNot in だと Null が抽出されないのは

以下のページに詳しく。 ACCESS クエリ 条件以外のレコードを抽出するには? – Access(アクセス) 解決済 | 教えて!goo <http://oshiete.goo.n …

no image

フォーム テンプレート

Accessのフォームを作るときに、「フォーム テンプレート」を使う方法があること、知っている人は多いのかな? 既存のフォームにあるテキストボックスの色やサイズなどの設定(プロパティ)を引き継いで、新 …

no image

access覚書

複雑な親子フォームを作る際、テーブル設定でインデックスを2つのフィールドとも「はい (重複あり)」にすることで、親のコンボボックスに子が連動するようになった。 Excelでコピーした表データをテーブル …