アクセスの2つのテーブルから重複しないものを抜き出す方法について

例えば テーブル Aには
ID   価格    商品
  1  200    りんご
  2  150    みかん
  3  180    りんご
  4  230    いちご

テーブル Bには
  1  150    みかん
  2  180    りんご

とあった場合 A-B のクエリーを実行して
  1  200    りんご
  2  230    いちご

という結果を得たいのですが、どのようにすれば出来るのでしょうか
よろしくお願いします。

このQ&Aに関連する最新のQ&A

A 回答 (5件)

"SELECT~FROM"は


クエリを新規に作成してクエリのデザイン画面の上部のテーブル等が表示される部分で右クリックしSQLビューに切り替えて表示される画面に入力します。
Selectの後は参照したいフィールド名、
Fromの後はテーブル名です。
Whereの後ろはデータを参照する条件を記述します。
SQLやAccessVBAを勉強されるときに参考に出来る書籍は山のようにありますので、書店で実際に見られて分かりやすいものを購入されるのがよいと思います。InterNetでもSQLを解説したページが沢山ありますので"SQL"や"ACCESS"等で検索されたらいかがでしょうか。
    • good
    • 0
この回答へのお礼

たいへん参考になりました
ありがとうございました
今後ももよろしくお願いいたします。

お礼日時:2001/02/06 18:12

SELECT テーブルA.ID, テーブルA.価格, テーブルA.商品


FROM テーブルA
LEFT JOIN テーブルB
ON (テーブルA.商品=テーブルB.商品) AND (テーブルA.価格=テーブルB.価格)
WHERE (テーブルB.ID) Is Null;
とすればよいと思います。
また、SQLを使わずとも不一致クエリーウィザードを使えば簡単に出来ます。
    • good
    • 0

select A.*


from A
where A.価格 not in ( select B.価格 from B )
;

でいいのでは??
「価格」を「商品」としても問題ないかと・・・・
    • good
    • 0

1.まず、UNIONクエリーでデータを統合します。


-1でかけているところがミソです。
VIEWを作ると使いやすいかもしれません。
このVIEWを統合テーブルという名前とします。

SELECT 価格 AS 価格,商品 AS 商品 FROM テーブルA
UNION ALL
SELECT 価格*-1 AS 価格,商品 AS 商品 FROM テーブルB

2.上記の統合テーブルから集計値を計算します。
SELECT SUM(価格),商品
FROM 統合テーブル
GROUP BY 商品

これで、OKだと思います。オラクルだとFROMにSELECT文がかけるので、1回でとれると思います。

なお、価格が0のものも出てしまいますが、これを除きたい場合は、HAVING句を使うなどしてください。

この回答への補足

早速の回答ありがとうございます。

さて、初歩的な質問で恐縮なのですが
SELECT...以下の文についてですが何処に書けば良いのでしょうか

また SELECT や FROM 等の構文については何を参照したら良いでしょか

全くのど素人が勉強するのに最適な参考書がございましたらご紹介ください。

補足日時:2001/01/30 15:48
    • good
    • 0

このままの状態だとちょっと難しいのでたとえばテーブルを



Aは
ID  価格    商品  商品コード
 1  200   りんご 101
 2  150   みかん 102
 3  180   りんご 103
 4  230   いちご 104
Bは
ID  価格    商品  商品コード
 1  150   みかん 102
 2  180   りんご 103
という風にします。
すると

SELECT テーブルA.商品コード
FROM テーブルA,テーブルB
WHERE テーブルA.商品コード = テーブルB.商品コード

これで重複している商品コードが取得できますのでこれをサブクエリにして
SELECT *
FROM テーブルA
WHERE 商品コード NOT IN (
   SELECT テーブルA.商品コード
   FROM テーブルA,テーブルB
   WHERE テーブルA.商品コード = テーブルB.商品コード)
UNION
SELECT *
FROM テーブルB
WHERE 商品コード NOT IN (
   SELECT テーブルA.商品コード
   FROM テーブルA,テーブルB
   WHERE テーブルA.商品コード = テーブルB.商品コード)
これで重複しないものが取得できます。
ちなみにご質問の例ですと重複しないものがテーブルAだけのようですので、それでよろしければ"UNION"句以降は要りません。
ただしこの方法(Not Inの使用)はデータ件数が多くなるほど処理の時間がかかるようになります。

この回答への補足

早速の回答ありがとうございます。

また、商品コードをつけたらいいという事ですが残念ながら初期のデータが膨大にあり後からつけるのが困難です。

さて、初歩的な質問で恐縮なのですが
SELECT...以下の文についてですが何処に書けば良いのでしょうか

また SELECT や FROM 等の構文については何を参照したら良いでしょか

全くのど素人が勉強するのに最適な参考書がございましたらご紹介ください。

補足日時:2001/01/30 15:57
    • good
    • 0

このQ&Aに関連する人気のQ&A

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています

関連するカテゴリからQ&Aを探す

このQ&Aを見た人が検索しているワード

このQ&Aと関連する良く見られている質問

Q2つのテーブルAとBをマージして新しいテーブルCを作成したいのです。

2つのテーブルAとBをマージして新しいテーブルCを作成したいのです。マージするときは、最新の売上日フィールドをもつレコードを取得します。環境はAccess2000です。どんなSQL文を作成すればいいのでしょうか? 
また、テーブルAにしかないレコード、又はテーブルBにしかないレコードは、そのままテーブルCに追加したいです。
※下記テーブルAとBは、Access内に存在します。テーブルCはAとBのマージ後の結果作成されるテーブルです。

テーブルA
顧客番号   売上日   商品名   備考
   1  2000-01-01  ふでばこ   A
   2  2000-02-02  鉛筆     A
   3  2000-03-03  定規     A
   4  2000-04-04  シャーペン  A
  99  2000-09-09  パソコン   A

テーブルB
顧客番号   売上日   商品名   備考
   4  2001-04-04  シャーペン  B
   2  2000-02-02  鉛筆     B
   3  2001-03-03  定規     B
   1  1999-01-01  ふでばこ   B
 100  2005-11-11  ワープロ   B


テーブルAとBを、最新の売上日の条件でレコードを取得し新しいテーブルCを作成する。

テーブルC
顧客番号   売上日   商品名   備考
   1  2000-01-01  ふでばこ   A
   2  2000-02-02  鉛筆     A
   3  2001-03-03  定規     B
   4  2000-04-04  シャーペン  A
  99  2000-09-09  パソコン   A
 100  2005-11-11  ワープロ   B

SQL文で処理可能なのでしょうか?

2つのテーブルAとBをマージして新しいテーブルCを作成したいのです。マージするときは、最新の売上日フィールドをもつレコードを取得します。環境はAccess2000です。どんなSQL文を作成すればいいのでしょうか? 
また、テーブルAにしかないレコード、又はテーブルBにしかないレコードは、そのままテーブルCに追加したいです。
※下記テーブルAとBは、Access内に存在します。テーブルCはAとBのマージ後の結果作成されるテーブルです。

テーブルA
顧客番号   売上日   ...続きを読む

Aベストアンサー

サブクエリでネストしても出来ない処理があるのでクエリを分けた方が簡単ですよ。
単純にするなら3つ

'qry1として
SELECT テーブルA.顧客番号, テーブルA.売上日, テーブルA.商品名, テーブルA.備考
FROM テーブルA
UNION SELECT テーブルB.顧客番号, テーブルB.売上日, テーブルB.商品名, テーブルB.備考
FROM テーブルB;

'qry2として
SELECT qry1.顧客番号, Max(qry1.売上日) AS 売上日の最大, qry1.商品名
FROM qry1
GROUP BY qry1.顧客番号, qry1.商品名;

'qry3として
'テーブルCを作成するなら
SELECT qry2.顧客番号, qry2.売上日の最大 AS 売上日, qry2.商品名, qry1.備考 INTO テーブルC
FROM qry2 INNER JOIN qry1 ON (qry2.売上日の最大 = qry1.売上日) AND (qry2.顧客番号 = qry1.顧客番号)
GROUP BY qry2.顧客番号, qry2.売上日の最大, qry2.商品名, qry1.備考;

'既存のテーブルCに追加するならこちらで
INSERT INTO テーブルC ( 顧客番号, 売上日, 商品名, 備考 )
SELECT qry2.顧客番号, qry2.売上日の最大, qry2.商品名, qry1.備考
FROM qry2 INNER JOIN qry1 ON (qry2.売上日の最大 = qry1.売上日) AND (qry2.顧客番号 = qry1.顧客番号)
GROUP BY qry2.顧客番号, qry2.売上日の最大, qry2.商品名, qry1.備考;

サブクエリで処理できるところもありますがその辺はご自分でネストしてみてください。

サブクエリでネストしても出来ない処理があるのでクエリを分けた方が簡単ですよ。
単純にするなら3つ

'qry1として
SELECT テーブルA.顧客番号, テーブルA.売上日, テーブルA.商品名, テーブルA.備考
FROM テーブルA
UNION SELECT テーブルB.顧客番号, テーブルB.売上日, テーブルB.商品名, テーブルB.備考
FROM テーブルB;

'qry2として
SELECT qry1.顧客番号, Max(qry1.売上日) AS 売上日の最大, qry1.商品名
FROM qry1
GROUP BY qry1.顧客番号, qry1.商品名;

'qry3として
'テーブルCを作成す...続きを読む

Qフォームをひとつのテーブルから作るときクエリーはつくりますか

フォームを作るとき,ひとつのテーブルから作るときでもクエリーを作るんですか?もしそうならそうする理由はなんでしょう?

Aベストアンサー

特にクエリを作らなくてもいいです。
でも、クエリを使うと抽出条件を付け加えることが出来ます。

Q選択クエリーで 2つのテーブルの項目が Null どうしのデータを抽出するには?

初心者です、教えてください。

テーブルが、2つあって
テーブル名: T1 T2
フィールド1: A1 B1
フィールド2: A2 B2
フィールド3: A3 B3
とあった時、選択クエリーで T1 と T2 のフィールドの A1-B1、A2-B2、A3-B3 が、
一致したものを表示するクエリーを作成します。
でも、A2、A3、B2、B3のデータ中には、それぞれ Null値が入っていて、
A2-B2、または、A3-B3 が、Nullどうしなら、一致とみなして、表示するには、
どうしたらいいのでしょうか?

Nullのみどうしのデータで、Nullのフィールドを
除いた選択クエリーをつくって、あとで合わせてもいいのですが、
実際のテーブルは、そういうフィールドが、いっぱいあって、大変なんです。

簡単に表示する方法は、あるでしょうか?

初心者なのでむずかしいことは、
やったことがなくて、すいませんが、わかる方がいらっしゃたら、お願いします。

Aベストアンサー

MS|ACCESSは持ってないので正確ではないかもしれませんが
。あっ、その前に表示させるときリストボックスで表示させるのかフォームで表示させたいのか書かれたほうがアドバイスが増えるかもしれません。

取り敢えず、書式タブの規定値を'0'にすればいいかも。
詳しいことは以下を参考にしてください。

参考URL:http://ac.accessclub.jp/beginer/cd/part_07.htm

QMs Access テーブルBにテーブルAのCDを充てたい。(クエリ?紐づけ?リレーションシップ?)

初心者です。よろしくお願いします。
そもそも、できるのかどうか、できたとして、どうするのかがわからないです。

次の2つのテーブルがあります。
テーブルマスタA には、①市町村CD ②市町村名 ③住所(番地なし)
テーブル受付データB には、①NO ②住所(番地まであり)③受付日 ④⑤・・・

具体的には、以下のとおり。(サンプル)
テーブルマスタA
①    ②      ③
10000  松戸市    千葉県松戸市
20000  鎌ケ谷市本町 千葉県鎌ケ谷市本町
30000  横須賀市   神奈川県横須賀市
テーブル受付データB
①    ②
1    千葉県松戸市五香5-5-5    
2    千葉県鎌ケ谷市本町さくらがおか8-88-8 ひまわりアパート302
3    神奈川県横須賀市横須賀8-7-8   

テーブル受付データBにおいて、②の部分(市町名まで)と、
テーブルマスタAの③をなんとか紐づけて、

クエリで合体させたい。
=テーブル受付データBに、テーブルマスタAの市町村CDを充てたい。
A①市町村CD  A②市町村名 B② B③ B④ B⑤
とすることを切望しています。

***********
たとえば、2つのテーブルに同じフィールドがあって、
それをリレーションシップで紐づけるのは容易ですが、
今回のようなパターンは、
もしかして、私は、ナンセンスなことをしようと苦闘している?と思ってきました。
フィールド名が同じじゃないのに、それを紐づけることができるのでしょうか?

できるとして、どのようにすればよいのでしょうか?

どうぞ、教えていただきたく、お願いいたします!!!

初心者です。よろしくお願いします。
そもそも、できるのかどうか、できたとして、どうするのかがわからないです。

次の2つのテーブルがあります。
テーブルマスタA には、①市町村CD ②市町村名 ③住所(番地なし)
テーブル受付データB には、①NO ②住所(番地まであり)③受付日 ④⑤・・・

具体的には、以下のとおり。(サンプル)
テーブルマスタA
①    ②      ③
10000  松戸市    千葉県松戸市
20000  鎌ケ谷市本町 千葉県鎌ケ谷市本町
30000  横須賀市   神奈川県横...続きを読む

Aベストアンサー

パラメータが表示されたのは指定したフィールドがないからです。
テーブル名とフィールド名を使用している名前に変更してください。

InStr関数は
ある文字列 (string1) の中から指定された文字列 (string2) を検索し、最初に見つかった文字位置を返す文字列処理関数です。
InStr(string1, string2)

やっていることはテーブル受付データBの②(住所)の中からテーブルマスタAの③(住所)を検索し
文字列がある位置を出しています。
必要なのは文字列が含まれているデータのみなので条件を>0としています。

試しにInStrの部分をなくしてクエリを実行してみてください。
「テーブルマスタA」のレコード数*「テーブル受付データB」のレコード数のデータが表示されるはずです。

Q2つのテーブルからクエリー作成

まず現状のご説明をさせていただきます。

「一覧テーブル」と「支払先一覧テーブル」があります。
「支払先一覧テーブル」には、
・No
・支払先名
・カナ
・銀行名
・支店
というフィールドがあります。
「一覧テーブル」には
・日付_年
・日付_月
・支払先No
・支払先
・入居者
・家賃
・駐車料
・総支払額
というフィールドがあります。

この2つのテーブルは、「支払先テーブル」の「No」と「一覧テーブル」の「支払先No」が
リレーションされています。

この2つのテーブルからクエリーをつくり、各支払先ごとに合計を取りたいと思い、以下のようなクエリーを作成しました。


デザインビューでクエリーを作成し、「支払先テーブル」と「一覧テーブル」をそれぞれ選択。
その中から、
・日付_年(一覧テーブル)
・日付_月(一覧テーブル)
・カナ(支払先一覧テーブル)
・銀行名(支払先一覧テーブル)
・支店(支払先一覧テーブル)
・総支払額(一覧テーブル)
をもってきました。
そのクエリを集計し、総支払額だけ「合計」にし、あとは「グループ化」にしました。

これで、支払先ごとの合計は出るかと思ったのですが、空欄になってしまいました。
どこが間違っているのか全然わかりません。
どうか教えてください。
よろしくお願いします。

Access2000を使用しています。

まず現状のご説明をさせていただきます。

「一覧テーブル」と「支払先一覧テーブル」があります。
「支払先一覧テーブル」には、
・No
・支払先名
・カナ
・銀行名
・支店
というフィールドがあります。
「一覧テーブル」には
・日付_年
・日付_月
・支払先No
・支払先
・入居者
・家賃
・駐車料
・総支払額
というフィールドがあります。

この2つのテーブルは、「支払先テーブル」の「No」と「一覧テーブル」の「支払先No」が
リレーションされています。

この2つのテーブルからク...続きを読む

Aベストアンサー

テキスト型でもできるのですが、実際に見ないとなぜ
「支払先NO」でデータを引っ張ってこれないのか
分からないので、今あるシステムを丸ごとコピーして、
「支払先テーブル」の「No」と「一覧テーブル」の「支払先No」を
数値型にして試してみてはいかがでしょうか。

今あるシステムが壊れない様にコピーしてから作業してみてください。


このQ&Aを見た人がよく見るQ&A

人気Q&Aランキング

おすすめ情報