- 締切済み
Accessで条件設定用のテーブルを作成する方法
Accessの条件設定用のテーブルを作成してクエリで結合する方法について質問があります テーブル名「名簿」(データ数99) ID 名前 役職 1 名前1 部長 2 名前2 次長 3 名前3 NULL 4 名前4 NULL 5 名前5 NULL ・・・ 99 名前99 NULL ※NULLは空欄で役職無し 上記名簿に対して 部長と次長は目標値0 特定の人物は目標値2 それ以外は目標値4 と設定したいのです。 下記の「目標値」のような 条件設定用のテーブルを作成し、 クエリで結合することは可能でしょうか? テーブル名「目標値」(データ数5) 名前 役職 目標値 * 部長 0 * 次長 0 名前3 * 2 名前5 * 2 * * 4 ※「*」はどの値でも関係なくヒットして欲しい クエリの結果としてほしいのは下記のような結果です クエリ(データ数99) ID 名前 役職 目標値 1 名前1 部長 0 2 名前2 次長 0 3 名前3 NULL 2 4 名前4 NULL 4 5 名前5 NULL 2 ・・・ 99 名前99 NULL 4 テーブル「名簿」の内容は変更できないものとします。 同じ結果が得られるのであればテーブル「目標値」は変更可能です。
- iori16
- お礼率66% (92/138)
- Access(アクセス)
- 回答数10
- ありがとう数1
- みんなの回答 (10)
- 専門家の回答
みんなの回答
- chayamati
- ベストアンサー率41% (254/607)
>ただ、NULLが含まれてると抽出できないので NULLが含まれていても抽出できるようにするために Nz(T名簿.名前,"") Like Nz(T目標値.名前,"") ----------------------------------------------------------- NZは「Is Null」です。 従ってSQLビューは 「SELECT 名簿.ID, 名簿.名前, 名簿.役職, 名簿.目標値 FROM 名簿 WHERE (((名簿.名前) Like "*" & [forms]![メニュー]![名前検索] & "*") AND ((名簿.役職) Like "*" & [forms]![メニュー]![役職検索] & "*") AND ((名簿.目標値) Is Null)) OR (((名簿.役職) Is Null));
- chayamati
- ベストアンサー率41% (254/607)
>なにやらフォームで入力した名前で抽出をしていますが、 これでクエリの結果が99件になるのでしょうか? 質問の本文で書いている通り99件結果が得られるようにしたい 質問の本文にあるとおり名簿テーブルの項目は「ID」と「名前」と「役職」のみです。 質問の最後に『テーブル「名簿」の内容は変更できないものとします。』と書いてある通り、 回答No.4の補足や回答No.5の補足でも伝えた通り、名簿テーブルは変更できません。 どうやら、chayamatiさんはどうあっても、 名簿テーブルに目標値を直接設定すべきだという考えをお持ちのようですが そもそもAというテーブルとBというテーブルをクエリで結合したいという質問に対し、 最初からAのテーブルに項目を追加して自分で入力したらいいという回答が返ってきたら、 本末転倒もいい所ではないですか? それとも、chayamatiさんは結合するクエリに対する質問は すべて大本のテーブルで項目を増やして、自分で入力すればいいと答えるのですか? クエリの存在意義を理解しているのか疑問です。 たしかにT目標値のテーブルが20件のレコードが必要とかであれば、確かに 20件も目標値を入力するなら大本のテーブルの99件を修正した方がややこしくなくていい となりますが、T目標値のレコードが5件で済むなら、大本のテーブルの99件を入力するより T目標値で5件入力して、あとはクエリで解決させようと考えるのはそんなにおかしいですか? おやおやそこはクエリで設定すべきか ----------------------------------------------------------- ・最初の質問には名簿テーブルだけでここには目標値の項目がありません そこで、役職というテーブル新規に追加して「目標値」を入れたのですが クエリの期待値が役職が「*」のとき目標値2,4があり、 「目標値」は名前で決めるのではないかと 「目標値」を名簿に追加しました テーブル名「目標値」(データ数5) 名前 役職 目標値 * 部長 0 * 次長 0 名前3 * 2 名前5 * 2 * * 4 ※「*」はどの値でも関係なくヒットして欲しい WHERE (((名簿.名前) Like "*" & [名前検索] & "*") AND ((名簿.役職) Like "*" & [役職検索] & "*")) [名前検査]または[役職検索]の入力窓に入力せずにOKクリックで全てが表示対象になります Like "*" & [名前検索] & "*"で名前検索が空白だとワイルドカードは「**」となります 尚、99件とはどのようなレコードでしょうか SQLにTOP関数があるようですが、SQLは自分はマスタしていません 下記のURLがご参考になりますか TOP (Transact-SQL) https://59log.com/?func=detail&id=148# ------------------------------------------------
補足
>>[名前検査]または[役職検索]の入力窓に入力せずにOKクリックで全てが表示対象になります それって名簿ってテーブルをただ開いてるだけですよね? 目標値は結局クエリではなく名簿テーブルに追加してますよね? なんの意味があるんですか? >>尚、99件とはどのようなレコードでしょうか 結果自体はchayamatiさんが提示しているものであっています。 私が問題にしてるのは 「テーブル「名簿」の内容は変更できないものとします。」という質問本文の前提を無視していることです。 何度もいいますが、名簿テーブルの定義は変更しないでください。 この質問は結果を出力することが目的というより 目標値を入力・管理する工数を減らすことが目的です。 結果があってればいいわけじゃありません。 書いてて気づきましたが、chayamatiさんは前提は違ってもいいから出力結果があってればいいと思ったということでしょうか? ちゃんと目的を質問本文に書いておけばよかったですね。すみません。 (ただ、何度も目的を補足で書いてるのに無視されるのでこまっているのですが)
- chayamati
- ベストアンサー率41% (254/607)
回答No.7の続きです ワイルドカード「*」の位置には何があっても検索対象から外れるため [[]内の文字列を検索対象とします [名前検索]、[役職検索]に何も記述せずにOKとするとすべてのレコードが表示されます また[名前検索]、[役職検索]をフォーム(例えばメニュー)に配置したテキストボックス、コンボボックスを Forms![メニュー]![名前検索] Forms![メニュー]![役職検索] と置き換えることが出来ます。 回答No.7のsqlビューは SELECT 名簿.ID, 名簿.名前, 名簿.役職, 名簿.目標値 FROM 名簿 WHERE (((名簿.名前) Like "*" & [名前検索] & "*") AND ((名簿.役職) Like "*" & [役職検索] & "*"));
補足
なにやらフォームで入力した名前で抽出をしていますが、 これでクエリの結果が99件になるのでしょうか? 質問の本文で書いている通り99件結果が得られるようにしたいと考えています >>回答No.7のsqlビューは SELECT 名簿.ID, 名簿.名前, 名簿.役職, 名簿.目標値 FROM 名簿 WHERE (((名簿.名前) Like "*" & [名前検索] & "*") AND ((名簿.役職) Like "*" & [役職検索] & "*")); なぜ名簿テーブルに目標値という項目があるのか分かりません。 質問の本文にあるとおり名簿テーブルの項目は「ID」と「名前」と「役職」のみです。 質問の最後に『テーブル「名簿」の内容は変更できないものとします。』と書いてある通り、 回答No.4の補足や回答No.5の補足でも伝えた通り、名簿テーブルは変更できません。 どうやら、chayamatiさんはどうあっても、 名簿テーブルに目標値を直接設定すべきだという考えをお持ちのようですが そもそもAというテーブルとBというテーブルをクエリで結合したいという質問に対し、 最初からAのテーブルに項目を追加して自分で入力したらいいという回答が返ってきたら、 本末転倒もいい所ではないですか? それとも、chayamatiさんは結合するクエリに対する質問は すべて大本のテーブルで項目を増やして、自分で入力すればいいと答えるのですか? クエリの存在意義を理解しているのか疑問です。 たしかにT目標値のテーブルが20件のレコードが必要とかであれば、確かに 20件も目標値を入力するなら大本のテーブルの99件を修正した方がややこしくなくていい となりますが、T目標値のレコードが5件で済むなら、大本のテーブルの99件を入力するより T目標値で5件入力して、あとはクエリで解決させようと考えるのはそんなにおかしいですか? おやおやそこはクエリで設定すべきか
- chayamati
- ベストアンサー率41% (254/607)
クエリ1 SELECT T名簿.ID, T名簿.名前, T名簿.役職, max(T目標値.ID) AS 目標値ID FROM T名簿 LEFT JOIN T目標値 ON (Nz(T名簿.名前,"") Like Nz(T目標値.名前,"")) AND (Nz(T名簿.役職,"") Like Nz(T目標値.役職,"")) GROUP BY T名簿.ID, T名簿.名前, T名簿.役職; クエリ2 SELECT クエリ1.ID, クエリ1.名前, クエリ1.役職, T目標値.目標値 FROM クエリ1 LEFT JOIN T目標値 ON クエリ1.目標値ID = T目標値.ID; -------------------------------------------------------------------------------- ・「JOIN」は同じテーブルはだめです」 ・「like」 は ワイルドカード「*」とともに使います。 添付の抽出条件行を見てください。 この行以下は抽出条件を記述します 同一行は&条件、行が異なればOR条件です。 ・また「GROUP BY」はSUM(目標値)のように「SUM」とともに使います
補足
No5の補足で私が書いたクエリの添削をしてくれたのでしょうか? ・「JOIN」は同じテーブルはだめです そうですね。 ちなみにクエリ1は 「T名簿」と「T目標値」を結合し、 クエリ2は「クエリ1」と「T目標値」を結合しているので 同じテーブルではありません。 ・「like」 は ワイルドカード「*」とともに使います。 そうですね。 なので T名簿.名前 Like T目標値.名前 と指定して「T目標値.名前」のレコードに「*」が入っていれば T名簿.名前にどんな値が入っていても基本的に抽出できるようにしました。 ただ、NULLが含まれてると抽出できないので NULLが含まれていても抽出できるようにするために Nz(T名簿.名前,"") Like Nz(T目標値.名前,"") としています。 ・また「GROUP BY」はSUM(目標値)のように「SUM」とともに使います そうですね。 ちなみにSUMだけでなくMAXという関数も使用できます。 なのでクエリ1ではMAXを使用していますね。
- chayamati
- ベストアンサー率41% (254/607)
>さらにクエリの結果を含むとさらにとんでもない行数になってしまいとてもではないですが、正しい結果が得られそうにありませんでした。 !テーブル間にリレーションシップがないときは 結果は2つのレコード件数の掛け算になります 名簿の件数が99、もう一つのテーブルの件数が10件とすると 99×10=9900件ととんでもない件数になります。 !クエリのレコードソースは回答No.4の添付のように 「名簿テーブル」ともう一つありませんか 名簿テーブルの IDはオートナンバー型で主キー 名前はユニーク設定になりませんか
お礼
すみません。補足を読み返していて、間違っている部分や分かりづらいところがあったので、 訂正いたします。 ×「同一のT目標値のIDを集計クエリで1つにまとめ」 ○「同一のT名簿のIDを集計クエリで1つにまとめ、T目標値のIDは最大のものを表示し」 ×「部長、次長、と特定の人物以外の目標値4の設定は必ずT目標値.IDが一番小さい値にする必要がある」 ○「下記のように名前と役職を「*」で指定する場合は必ずT目標値.IDが一番小さい値にする必要がある」 名前 役職 目標値 * * 4
補足
回答No.1についてですが、回答No.3で回答者本人が述べている通り、内容が間違っていたようです。 (途中まではほとんどあっていたので参考にはなりました) 本当は画像がついていたのですが、削除されています。 >>名簿テーブルの >>IDはオートナンバー型で主キー >>名前はユニーク設定になりませんか その程度の変更は可能です。 というよりすでになっていると思います。 とりあえず、自分でもいろいろ試してみて次のようにクエリを組んでみました まず「T目標値」テーブルを次のように設定し、クエリ1とクエリ2のクエリを2つ作成しました。 (クエリ1はデザインビューで表現できないのでSQLビューでコピーアンドペーストすると試すことが可能です) ID 名前 役職 目標値 1 * * 4 2 * 部長 0 3 * 次長 0 4 名前3 * 2 5 名前5 * 2 クエリ1 SELECT T名簿.ID, T名簿.名前, T名簿.役職, max(T目標値.ID) AS 目標値ID FROM T名簿 LEFT JOIN T目標値 ON (Nz(T名簿.名前,"") Like Nz(T目標値.名前,"")) AND (Nz(T名簿.役職,"") Like Nz(T目標値.役職,"")) GROUP BY T名簿.ID, T名簿.名前, T名簿.役職; クエリ2 SELECT クエリ1.ID, クエリ1.名前, クエリ1.役職, T目標値.目標値 FROM クエリ1 LEFT JOIN T目標値 ON クエリ1.目標値ID = T目標値.ID; これはNo2の補足で述べた方法の問題点 ID 名前 役職 目標値 1 * * 4 と 2 * 部長 0 というレコードが重複した条件として判定されてしまい クエリの結果が99件を超えてしまうという問題を 同一のT目標値のIDを集計クエリで1つにまとめ、 そのクエリ結果にもう一度T目標値テーブルを結合しなおしたものとなります。 これで一応できているのですが、 T目標値.IDが大きい方が優先されるため、 部長、次長、と特定の人物以外の目標値4の設定は必ず T目標値.IDが一番小さい値にする必要があるという問題があります。 一応下記のようにT目標値.IDの1番目に設定し ID 名前 役職 目標値 1 * * 4 その下のレコードに部長、次長、特定の人物の条件を追加することで実装はできました。 できればクエリを1つにまとめ、 T目標値のIDの順番に依存しない形で作りたかったのですが、難しそうですかね。
- chayamati
- ベストアンサー率41% (254/607)
「おやおや」の気持ち分かっていただきましたか 最初目標値は役職毎に固定のものと思ってました。 なので、昇級すると目標値も変更するものと思っていましたが 質問の終わりの方に、役職がNullの時目標値が0,2,4があり、任意のような気がします。 目標値は役職で決まるのでなく 職種(事務、製造、営業)学歴、年齢等他の要素のようですね 余計なことを考えずに、 名簿テーブルに目標値の項目を追加するだけではだめですか
補足
>>目標値は役職で決まるのでなく職種(事務、製造、営業)学歴、年齢等他の要素のようですね 正確には、部長、次長は目標値0固定で、 それ以外はほとんどが目標値4なのですが 例外で目標値2の人が数名います。 なので、部長、次長を目標値0、 特定の人物を目標値2 と設定し、それ以外を目標値4と設定したいのです。 >>名簿テーブルに目標値の項目を追加するだけではだめですか 名簿テーブルは私の管理ではないので、勝手に設定することはできないですし、設定すると何十もの目標値を設定する必要があり、変動するたび、名簿テーブルを管理している人に修正してもらう必要が出てきます。 そのため、最初の質問にある通り テーブル「名簿」の内容は変更できないものとします。
- chayamati
- ベストアンサー率41% (254/607)
添付のように役職テーブルを追加して目標値を役職テーブルに入れます 名簿テーブルのデザインビューで役職テーブルをルックアップします。 おやおや目標値は名簿テーブルに定義すべきか
補足
この方法だと部長や次長に対して目標値0を設定することはできますが、名前3、名前5に対して目標値2を設定することができていません。 >>おやおや目標値は名簿テーブルに定義すべきか 名簿テーブルは部内で共有で仕様しているアクセスファイルからリンクテーブルで持ってきていて、勝手に設定することができません。 仮にできたとして、何十の数値を設定してそれを逐次修正したり管理するのは面倒です。 その為、部長、次長は目標値0、特定の人物(名前3、名前5)は目標値2、それ以外は4という最低限の設定でテーブルで設定して、クエリで表示したいです。
- kkkkkm
- ベストアンサー率65% (1620/2459)
すみませんNo1は間違ってましたので、無視してください。
- kkkkkm
- ベストアンサー率65% (1620/2459)
No1の追加です。 書き忘れてましたが、テーブル「目標値」で「*」などワイルドカードを使うと、クエリの条件に入れるときなどに="*"とせずに単純に"*"としたらLike "*"になってしまったりしますし、後々他の個所でうっかり勘違いしそうな気もします。
補足
おっしゃる通りクエリの抽出部分に「*」を使用すると自動で「Like "*"」になりますが、例えば 抽出条件に Where 句にNz([T名簿].[名前],"") like Nz([T目標値].[名前],"") と指定したり デザインビューで表現はできないですが LEFT JOINのON句に Nz([T名簿].[名前],"") like Nz([T目標値].[名前],"") と指定してうまくテーブルの「*」をLike演算子でうまくできないかと思って行っています。 ※テーブル名に分かりやすく先頭にTをつけました 例えば下記の例です(デザインビューで表現できないのでSQLビューでコピーアンドペーストすると試すことが可能です) SELECT [T名簿].[ID], [T名簿].[名前], [T名簿].[役職], [T目標値].[目標値] AS 目標値 FROM [T名簿] LEFT JOIN T目標値 ON (Nz([T名簿].[名前],"") like Nz([T目標値].[名前],"")) AND (Nz([T名簿].[役職],"") like Nz([T目標値].[役職],"")); この例では「T目標値」の * 部長 0 と * * 4 が重複した条件と判定されてしまうため、 レコードが99件を超えてしまい失敗しました。
- kkkkkm
- ベストアンサー率65% (1620/2459)
名前3 * 2 名前5 * 2 の役職の所はNULL(もしくは*以外)にしておいてください。 添付画像のクエリ(2個)を作成してクエリ1で結果を試してみてください。
補足
今まで返信できなくてすみません。 Accessに触れる機会がなくて確認ができませんでした。 実際に試してみましたが、2つテーブルと1つのクエリの直積(交差結合)から条件で抽出しているようですが、2つのテーブルの直積の時点で99×5=495行ほどのレコードが存在し、さらにクエリの結果を含むとさらにとんでもない行数になってしまいとてもではないですが、正しい結果が得られそうにありませんでした。
関連するQ&A
- accessのテーブル二つで一つのテーブルを
ACCESS97を使用しています。 テーブル1 製品番号 出荷日 出荷数 100 2012/12/1 3 101 2012/12/13 2 105 2012/12/1 5 108 2012/12/5 6 テーブル2 製品番号 売上日 売上数 売上金額 100 2012/12/1 3 3,000 101 2012/12/13 4 5,000 111 2012/12/10 10 500 二つのテーブルがあり、どちらもfrom to の期間指定で大きなテーブルから取り出しています。テーブル1のみにあるデータ、テーブル2にあるデータどちらにもあります。 これを一つのテーブルにまとめて下記のようにしたいのですが、できますか。 製品番号 出荷日 出荷数 売上日 売上数 売上金額 100 2012/12/1 3 2012/12/1 3 3,000 101 2012/12/13 2 2012/12/13 4 5,000 105 2012/12/1 5 null null null 108 2012/12/5 6 null null null 111 null null 2012/12/10 10 500 このようなテーブルにしたいのですが、できますか。 access使用歴は長いのですが、簡単なクエリとかしかできなくてなさけなく思っています。これを機に少し勉強したいと思ってますが、取り掛かりからわかりません。よろしくお願いいたします。
- 締切済み
- 財務・会計・経理
- 【Access2000】テーブルを検索条件にした削除クエリ
テーブル1 ID 名前 1 さとう 2 たかはし 3 こんどう 4 やまだ 5 いしかわ テーブル2 ID 2 4 5 上記、データを使用して、「テーブル2に登録されているIDが同じレコードを、テーブル1から削除するためのクエリ」を作成することは出来ますでしょうか? 結果として以下のようになることが希望です。 テーブル1 ID 名前 1 さとう 3 こんどう 削除クエリを作成して、条件で"ID=2"とすれば"2 たかはし"はもちろん削除されます。 しかし、条件を"like [テーブル2]![ID]"としても何も削除されません。 このような処理は可能でしょうか? 可能であればSQLを記述せずに実現させたいのですが可能でしょうか? (SQLは未熟者でして。。。) よろしくお願い致します。
- ベストアンサー
- オフィス系ソフト
- accessテーブル作成クエリについて
テストで6個のテーブルから必要なテーブルを作成するクエリを作りました。 本日新しい本番データができたのでこのDBにテストでOKだったクエリを「ファイル」-「外部データ。。。」-「インポート」しました。 クエリを実行したところレコードがゼロという結果になりました。 テストでOKだったクエリを「コピー」-「貼り付け」しても同じ結果でした。 クエリを別のDBで使用するにはどうしたらよいのでしょうか? 毎月データが更新されるためDBの名前は、「工場0906」「工場1003」のように工場+月日となります。 よろしくお願いします。
- ベストアンサー
- その他MS Office製品
- Access 複数テーブルのリレーションシップ
Access2013 4種類の名簿をそれぞれのテーブル(4種類)で管理してありますが、 同じ方(氏名)が4種類の名簿全部には無く、2つや3つの名簿にばらばらにあります。 この4つのテーブルを同時に表示し入力できる分割フォームをつくりたいのですが、 この際の、4つテーブルの氏名をリレーションシップする結合プロパティの設定方法を教えて下さい。 あるいは、クエリのそれぞれのテーブルのフィールド(氏名)の抽出条件になんと書き入れたらよいか。教えて下さい。 宜しくお願いします
- ベストアンサー
- その他MS Office製品
- ACCESS2007で同じテーブルから繋ぐことはできますか。
ACCESS2007で同じテーブルから繋ぐことはできますか。 実際に作るのはもっとテーブル数も項目も多いので、不明な箇所だけを簡略した例は次のものです。 都道府県テーブル:K_No、都道府県名 名簿テーブル:M_No、名前、本籍地、居住地(2か所にK_Noは入れられませんよね?) 本籍地と居住地には都道府県.K_Noを入れたいのですが、一つの都道府県テーブルのNoを名簿テーブルの本籍地と移住地の2箇所にリンクすることはできますか。 名簿.M_No、名簿.名前、名簿.本籍地、都道府県.都道府県名、名簿.居住地、都道府県.都道府県名でクエリを作りましたら、 都道府県から名簿へリンクの線が2本出るクエリでは、本籍地と居住地が同じものだけが抽出されました。 都道府県(No)-(本籍地)名簿(居住地)-(No)都道府県_1と3テーブルになると全レコードは表示されますが、本籍地も居住地も居住地のNoの名前が出てしまいます。 本籍地用と居住地用の都道府県テーブルを別に用意しなければならないのでしょうか。何箇所同じ地方コードを入れる箇所(本籍地、居住地、勤務地、別居家族の居住地など)があるので一つのテーブルを共有できたら、と思っています。
- ベストアンサー
- その他MS Office製品
- Accessクエリでのグループ化
Accessクエリでのグループ化 以下の2つのテーブルが有ります。 ■社員テーブル ID 名前 1 Aさん 2 Bさん 3 Cさん 4 Dさん 5 Eさん ■受付テーブル ID 受付内容 受付日 社員ID 1 xxxxx 2010/3/1 1 2 xxxxx 2010/3/20 3 3 xxxxx 2010/4/10 2 4 xxxxx 2010/4/11 5 5 xxxxx 2010/4/15 1 6 xxxxx 2010/4/30 2 7 xxxxx 2010/5/3 4 そこで社員毎の受付数をカウントしたいと思っています。 ※受付日が2010/4/1以上5/1未満 名前 受付回数 Aさん 1 Bさん 2 Cさん 0 Dさん 0 Eさん 1 となるイメージです。 しかし、実際にクエリを作ると結果が 名前 受付回数 Aさん 1 Bさん 2 Eさん 1 と、なってしまいます。。 名前:グループ化 受付テーブルのID:カウント 受付日:>=2010/04/01 and <2010/05/01 ※社員テーブルの『ID』と、受付テーブルの『社員ID』を 紐つけており、結合プロパティでは『社員テーブルの 全レコードと受付テーブルの同じ結合フィールドのレコード だけを含める』としております。 あらかじめ、受付テーブルで受付期間の条件でクエリ を作成しておき、それと社員テーブルを紐つけた場合は イメージ通りの結果になるのですが、1つのクエリで 上記イメージでの結果を表示したいと思ってます。 可能でしょうか? ご教授願います。
- ベストアンサー
- その他(データベース)
- アクセス97マクロ:テーブルデータ削除の条件設定方法について教えてください。
どうぞ教えてください。 毎月仕事上である処理が終わった後に、いくつかのテーブルのデータの一部を削除する作業があり、これをマクロで自動的に処理できるようにしようと考えました。 そこで、最初は削除したいテーブルごとに削除クエリを作り、Where条件として削除したいデータの年月を尋ねるようにし、これをマクロで「クエリの実行」として複数の削除クエリを一気に実行してまとめて処理しようとしました。 上記でも処理はうまくいきます。 ただ、もしクエリを使わずにマクロだけでこのような処理が可能なのであれば、クエリの数も減るため、できればそうしたいと考えています。 その場合、マクロデザイン画面で「テーブルを開く(テーブル名入力)」→「レコードの選択」→「削除」とすれば削除はできると思うのですが、全てのレコードを削除するわけでなく条件に合致する一部のデータだけ削除したい今回のような場合、Where条件(年月)をマクロ上で尋ねるor設定するにはどうしたらいいでしょうか?
- ベストアンサー
- オフィス系ソフト
- Access 複数テーブルをまとめる
こんにちは! 過去記事を検索しましたが、該当がなく、苦戦しております… お知恵をお貸し下さいm(__)m テーブル T顧客…顧客ID(主キー)、名前、… T書類1…顧客ID(重複キー有)、書類1ID、… T書類2…顧客ID(重複キー有)、書類2ID、… T書類3…顧客ID(重複キー有)、書類3ID、… T書類4…顧客ID(重複キー有)、書類4ID、… ・ ・ ・ その他に複数同じような構造のテーブルがあります。 テーブル内には他に様々なフィールドがありますが、同一内容の結合できるフィールドは上記のみです。 上記のテーブルですべての書類IDを取ってきたいのですが、 全テーブルを顧客IDと結合し、選択クエリで抽出すると 顧客ID | 名前 | 書類1ID | 書類2ID | 書類3ID | 書類4ID 1 | Aさん | 10 | 5 | 20 | 26 1 | Aさん | 10 | 30 | 20 | 25 1 | Aさん | 10 | 4 | 20 | 26 1 | Aさん | 10 | 6 | 20 | 25 2 | Bさん | 30 | 13 | 25 | 5 2 | Bさん | 30 | 10 | 26 | 5 2 | Bさん | 30 | 13 | 26 | 5 2 | Bさん | 30 | 10 | 25 | 5 のような値が出てきてしまいます…当たり前の結果ですが… やりたいこととして、 (1)一つのテーブルかクエリで抽出 顧客ID 名前 書類1ID 書類2ID 書類3ID 書類4ID 1 Aさん | 10 | 5 | 20 | 26 | | 30 | | 25 | | 4 | | 6 2 Bさん | 30 | 13 | 25 | 5 | | 10 | 26 のように重複をなくし、 (2)更にまとめたものにしたいです。 顧客ID 名前 書類1ID 書類2ID 書類3ID 書類4ID 1 Aさん 10 5,30,4,6 20 25,26 2 Bさん 30 10,13 25,26 5 最終的に上記にまとまったものをフォームにして、顧客IDごとに抽出し、 顧客ごとの各書類のIDはこれとこれですよ!みたいにしたいのです! 説明が下手で申し訳ありませんm(__)m Access初心者で、独学でコツコツやっているので、知識が乏しいです… 調べてみるとユニオンクエリとかでできるような記事はありますが、 SQL文なども理解ができずに苦戦しております… お手数ですが、ご教示の程 よろしくお願い申し上げます。
- ベストアンサー
- オフィス系ソフト
- MS accessで2つのテーブルを比較したい
数々この質問は出ているのですが、『不一致クエリウィザード』でやっても上手くいかないので、こちらで質問させていただくことにしました。 比較したいデータは、フィールドの名前が異なる2つのテーブルがあって、その比較したいフィールド数は120になります。 同一フィールドは「FID」「laa」というフィールドです。 一応自分で『不一致クエリウィザード』でやってみた手順としては以下の通りになります。 1.『不一致クエリウィザード』をクリック 2.どちらかのテーブルを選択(レコード抽出テーブルや比較するテーブルなど) 3.関連付けフィールドは、2つのテーブルで同じものを選択 (「FID」「laa」を選択) 4.結果を表示するフィールドを選択(120個全部) 5.「クエリのデザインを編集する」の方にチェックを入れて「完了」 6.クエリのデザインになったら、それぞれの名前は違うけど対応するフィールド同士をつなぐ 7.結合プロパティで2番ないし3番を選択 8.それを全部のフィールドにした ↓ すると「クエリが複雑すぎます」とエラーメッセージが出てしまった。 一体どうすればよいのでしょうか? なにぶん初心者ですので、よろしくお願いします。 ※もしかして、フィールド名が異なっているのはダメなのでしょうか?
- ベストアンサー
- その他MS Office製品
- Accessのクエリ作成について
クエリを作成する際の、テーブルの設定の仕方がよくわかりません。 たとえば、「顧客リスト」テーブルと「販売履歴」テーブルに、それぞれ「顧客ID」フィールドがあり、「顧客ID」フィールドがリレーションシップで設定されているとします。 新たに、選択クエリを作成し、そのクエリに、「顧客ID」フィールドを設定するときに、どちらのテーブルの「顧客ID」フィールドを設定するかがわかりません。 ちなみに顧客IDフィールドには、リレーションシップを設定していて、1対多の設定をしています。 「顧客リスト」テーブルの「顧客ID」フィールドが、「1」の側で、 「販売履歴」テーブルの「顧客ID」フィールドが「多」の側です。 どちらのテーブルを使用しても結果は同じなのですが、 選択クエリを作成するときに、上記のように、同じフィールドを持テーブルが2つありリレーションシップを 設定している場合は、どちらのテーブルを使わないといけないというような決まりはあるのでしょうか? どちらを使用しても構わないのでしょうか。 特に、決まりがない場合は、一般的には、どのように設定されているのでしょうか?
- 締切済み
- その他(データベース)
補足
今回の質問では2つのテーブルを結合する方法を質問しています。 それがchayamatiさんは なぜ1つのテーブルの抽出方法を答えているのでしょうか? 私はテーブルを抽出したいのではなく、結合したいのです。 クエリの結合で列を追加したいと難度も伝えているにもかかわらず、chayamatiさんは最初から名簿に 目標値という項目を追加し、聞いてもいない抽出条件についてばかり述べていますよね? 何がしたいのか理解できません。