AccessクエリでYes/No型データの抽出条件について教えてください。
フォーム上のオプショングループにオプションボタン 1:Yes 2:No 3:両方 の3つを作成し、選択したオプション値によって抽出条件を変えたいのですが、
Choose([Forms]![オプショングループ名],-1,0,-1 Or 0)とすると3:両方を選択した際に、Yesのデータしか抽出できませんでした。
ただ、-1 Or 0 を -1 Or 1 としたら、両方抽出されました。
処理的には解決できたのでOKなのですが、理由がわからずちょっと気持ち悪いので。。。
よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
Choose([Forms]![オプショングループ名],-1,0,-1 Or 0)
の関数が返す値と、Yes/No型のデータとを比較して抽出したという事ですよね?
Choose([Forms]![オプショングループ名],-1,0,-1 Or 0)
この関数は
オプショングループ名 = 1 の場合 → -1
オプショングループ名 = 2 の場合 → 0
オプショングループ名 = 3 の場合 → -1 or 0
の値を返します。
そうなると抽出条件の論理式は
1:Yesの場合 → データ = -1
2:Noの場合 → データ = 0
3:両方の場合 → データ = -1 or 0
となりますが、この3番目の式は
「データが -1 もしくは 0 の場合」という意味にはなりません。
「データ = -1」もしくは「0」のどちらかの条件を満たす場合、という意味になってしまいます。
データと比較されるのはあくまでイコールの直後にある数値だけで
括弧を付け加えると (データ = -1) or ( 0 ) のようなイメージです。
この論理式は、データが -1 であった場合には
-1(True)が返ってきて「条件を満たしている」と判定されますが
データが -1 でなかった場合は
0(False)が返ってきて「条件を満たしていない」と見なされます。
同じように考えると データ = -1 or 1 の論理式は
データ = -1 の場合 → -1
データ <> -1 の場合 → 1
の値が返ってくる事になります。
論理式というのは、返ってきた値が 0 の場合は「条件を満たしていない」と見なし
返ってきた値が 0 以外であればすべて「条件を満たしている」と見なすので
こちらの場合はデータの値と関係なく
すべてのレコードを抽出するような条件式になってしまうのです。
ありがとうございました!論理式をよく理解しないまま使用しておりました。大変勉強になりました。
ということは、条件式はこんな感じでしょうか?
Choose([Forms]![オプショングループ名],-1,0,([Forms]![オプショングループ名])=True)
ちなみに・・・この処理でChoose関数を使うこと自体、おかしいのでしょうか?
他に良い方法がありましたら教えてください。
No.3
- 回答日時:
#1です。
「=(イコール)」はあくまで左右にある一つずつの値を比較するだけですので
「データが -1 か 0 のどちらか」という事を意味する論理式は
(データ = -1) or (データ = 0)
や
データ in(-1, 0)
という形になります。
(ただし後者の in が使えるのはクエリ等のSQLの条件式のみ)
抽出条件をどのように設定しているかにもよりますが
クエリのデザインで抽出条件の欄にChoose関数をセットされているのであれば
抽出条件の1行目には
=Choose([Forms]![オプショングループ名],-1,0,0)
2行目(または: の行)には
=Choose([Forms]![オプショングループ名],-1,0,-1)
を入れておくという形ではいかがでしょうか。
その後SQLビューで見てみると分かりますが、条件式は
(データ = Choose([Forms]![オプショングループ名],-1,0,0))
OR (データ = Choose([Forms]![オプショングループ名],-1,0,-1))
という記述になり
オプショングループ = 1 の場合
→ (データ = -1) OR (データ = -1)
オプショングループ = 2 の場合
→ (データ = 0) OR (データ = 0)
オプショングループ = 3 の場合
→ (データ = 0) OR (データ = -1)
という意味になってきます。
オプショングループが 1, 2 の場合にはChoose関数の返す値は同じですので
2行目の「または」の条件に意味はありませんが
オプショングループが 3 の場合はChoose関数の返す値が異なりますので
「または」のOR条件が生きてくる形になります。
No.2
- 回答日時:
エクセルのCHOOSE関数は=CHOOSE(INDEX,値1、値2、・・・)の形をしており、INDEXは1より小だとエラーに成ります。
INDEXに実数を指定しても切り捨てて整数として扱われる。値1・・はあくまで値であって、=CHOOSE(A1,"a",C1+3,"c")のように式は入れることは可能ですが処理ルーチンは指定しようがありません。
Accessはエクセルと同じである必要もなく、全く同じかどうか判りませんが、[Forms]![オプショングループ名]で決まる値は1,2,3ではなく1、0、-1を取るとすればおかしいのではないでしょうか。アクセスではそれぞれボタンの値は0と-1をとるようですが。
また第2以下の引数に1OR0を(OR入り)指定するのはおかしいのではないでしょうか。
無知のためとんでもないことをいっていたら済みません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
推しミネラルウォーターはありますか?
推しミネラルウォーターがあったら教えてください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
YES/NO型の値
Excel(エクセル)
-
access クエリ yes/no型のクエリの抽出の記述を教えて下さい。
Access(アクセス)
-
クエリで出来た表にチェックボックスを追加する
その他(Microsoft Office)
-
-
4
Access チェックボックスを利用した絞込検索のクエリ記述
その他(Microsoft Office)
-
5
access2019 チェックボックスと連動したクエリ抽出条件について
Access(アクセス)
-
6
アクセス:Yes/No型→チェックいれたら、○"を表示。"
Access(アクセス)
-
7
yes/no型のチェックができない(アクセス2003)
Access(アクセス)
-
8
アクセス2016 チェックボックス☑表記が-1,0表記になってしまったので直す方法
Access(アクセス)
-
9
Accessで文字列の長さによって、フィールドの幅を自動で合わせる方法
Excel(エクセル)
-
10
ACCESSでテーブルにあるチェックボックスを一括でYesにする方法を教えてください
Access(アクセス)
-
11
ACCESS フォームをそのまま印刷について
その他(データベース)
-
12
Access フォームのテキストボックスに半角英字のみで入力する設定は
Access(アクセス)
-
13
Access サブフォームでの選択行の取得
その他(データベース)
-
14
アクセスのコンボボックスの重複をなくすには?
Access(アクセス)
-
15
テキストボックスにクエリ結果を表示させたい
その他(データベース)
-
16
Access チェックボックスでチェックしたデータのみフォームで表示
Access(アクセス)
-
17
ACCESS VBA テーブルデータにYES/NO
Visual Basic(VBA)
-
18
ACCESSで空白のデーターをクエリで判定/識別する方法を教えてくださ
Access(アクセス)
-
19
Access2010 「演算子がありません」エラー
その他(データベース)
-
20
ラベルとテキストボックスのグループ化を解除したい
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
イタリアから帰国する際、肉製...
-
精液の落とし方を教えてください
-
検便についてです。 便は取れた...
-
勃起する時って痛いんですか? ...
-
エクセルで数式の答えを数値と...
-
エクセル指定した範囲からラン...
-
精子に血が・・・
-
2つの数値のうち、数値が小さい...
-
EXCELで条件付き書式で空白セル...
-
これって喉仏ですか? 私は女性...
-
風俗店へ行く前のご飯
-
精子が黄色?
-
甲状腺が腫れているが血液検査...
-
リンク先のファイルを開かなく...
-
小数点以下を繰り上げたものを...
-
【Excelで「正弦波」のグラフを...
-
excelでsin二乗のやり方を教え...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
勃起する時って痛いんですか? ...
-
精子が黄色?
-
検便についてです。 便は取れた...
-
これって喉仏ですか? 私は女性...
-
小数点以下を繰り上げたものを...
-
甲状腺が腫れているが血液検査...
-
精液の落とし方を教えてください
-
エクセル指定した範囲からラン...
-
EXCELで条件付き書式で空白セル...
-
2つの数値のうち、数値が小さい...
-
精子に血が・・・
-
エクセルのラベルの値(文字列...
-
イタリアから帰国する際、肉製...
-
ある範囲のセルから任意の値を...
-
リンク先のファイルを開かなく...
-
中出しをするとお腹が痛い・・・。
-
MIN関数で空白セルを無視したい...
おすすめ情報