2つのテーブルから条件に一致しない行のみ抜き出しCSV
か他のテーブルに抜き出す処理を作ろうと思っています。
そこで質問なのですが、以下の2つのテーブルから
条件に一致しないコードのみ抜き出すSQL文などありますか?
-----------------------------------------
マスターテーブル
コード、ネーム1、ネーム2、店コード
1、あ、い、6
2、う、え、8
3、お、か、4
4、き、く、2
店コードテーブル
店コード、店区分
1、スーパー
2、コンビニ
3、デパート
4、ホームセンター
------------------------------------------
条件は、マスターテーブルの店コードが店コードテーブルに存在
しないデータのみ抽出です。
抽出結果は、以下の様にしたいです。
1、あ、い、6
2、う、え、8
このような考え大丈夫でしょうか?
SELECT *
FROM マスターテーブル AS M INNER JOIN 店コードテーブル AS S
ON M.店コード = S.店コード
わかりずらい質問ですがよろしくお願いします。
No.2ベストアンサー
- 回答日時:
このような考え大丈夫でしょうか?
SELECT *
FROM マスターテーブル AS M INNER JOIN 店コードテーブル AS S
ON M.店コード = S.店コード
店コードが一致するレコードを抽出しているのですね。
はい、大丈夫です。
もっとも単純に、分かりやすい式を書くのであれば
この条件否定なので
left outer join で結合して、結合できなかったデータ、
つまり、店がNullのデータを取れば抽出できます。
SELECT *
FROM マスターテーブル AS M left outer join 店コードテーブル AS S
ON M.店コード = S.店コード
where S.店コード is null
または、
SELECT *
FROM マスターテーブル as M
where M.店コード not in ( select 店コード from 店コードテーブル)
等でいけるでしょう。
ただ、参考URLにもありますように、
is null とか not in は遅いです。(Indexで見れなくなるので)
大量データを扱うような場合や、速度が求められるような場合は
別途クエリを検討しましょう。
参考URL:http://www.geocities.jp/mickindex/database/db_op …
No.1
- 回答日時:
>SELECT *
>FROM マスターテーブル AS M INNER JOIN 店コードテーブル AS S
>ON M.店コード = S.店コード
上記のようにINNER JOINしてしまうと、両テーブルに存在する店コードの行のみ選択されます。
外部結合を行って、マスターテーブルの全行を戻し、WHERE句で店コードテーブル側に存在しない(IS NULLを指定)行を選択します。
または、以下のように「not in」「not exists」を使う方法もあります。
select M.*
from マスターテーブル AS M
where M.店コード not in (select 店コード from 店コードテーブル AS S);
select M.*
from マスターテーブル AS M
where not exists (select 店コード from 店コードテーブル AS S WHERE M.店コード = S.店コード);
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle SQL update方法 2 2022/06/22 14:07
- MySQL SQLです。こんな感じですか?あってますか? うまくいきません教えてくださいお願いします 1 2023/07/08 15:27
- MySQL うまくいきません教えてくださいお願いしますSQLです。クエリ構文です。 1 2023/07/07 12:39
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- Access(アクセス) AccessVBAで降順にするテーブル作成クエリを使用して作成したテーブルを削除し同一のテーブル作成 1 2023/01/06 11:17
- Visual Basic(VBA) 配列にしたセル範囲でのコメントがあるかどうかを取得するコードの書き方 2 2022/09/17 05:09
- PostgreSQL PostgreSQL レコードからアイテム種類数を取得したい 2 2022/11/23 22:31
- MySQL 複数DBテーブルからのデータ取得 3 2022/05/17 15:02
- Oracle sqlで質問です。 idを元にidに紐付くデータで住所コードがjpのみのデータ以外のidを取得したい 4 2023/03/20 17:41
- Oracle sqlで質問です。 Aテーブルの情報をBテーブルに更新かけたいです。 やりたいことは、Bテーブルの受 1 2023/05/17 11:17
このQ&Aを見た人はこんなQ&Aも見ています
-
「どうして捨てられないの?」前妻の物を捨てられない男性の心理って?
前妻の物を捨てられない理由に加え、捨てるための手段はあるのかを専門家に聞いてみた!
-
【SQL】他テーブルに含まれる値に合致する行を抽出
その他(データベース)
-
GROUP BYを行った後に結合したい。
Oracle
-
SQLで、Join句で結合したテーブルにデータが無い場合について
SQL Server
-
-
4
2つの列が同じ値の行を取得するSQL
Oracle
-
5
SQLで特定の項目の重複のみを排除した全項目を取得する方法
その他(プログラミング・Web制作)
-
6
SQL、2つのテーブルで条件一致したものだけdeleteする方法は?
Oracle
-
7
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
8
副問合せの書き方について
SQL Server
-
9
SQL Left Join で重複を排除するには
SQL Server
-
10
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
-
11
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
12
MS SQLServer のSQLで文字列の前にN:
その他(データベース)
-
13
2つの項目が重複するレコードを抽出する方法はありますか?
MySQL
-
14
CASE文のエラーについて
Oracle
-
15
ROWNUMでUPDATEをしたいのですが・・・。
Oracle
-
16
SQLServerでNULLを挿入したいです
SQL Server
-
17
フルパスから最後のディレクトリ名を取得したい。
Visual Basic(VBA)
-
18
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
19
[SQL]重複内容を持つデータから1件抽出かつ複数のカラムを表示したい
その他(データベース)
-
20
SQL 重複しないJoinの仕方を教えてください
MySQL
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
PLSQLの識別子エラー
-
ACCESS 一つのフィールドに複...
-
2つのテーブルから条件に一致...
-
主キーの変更
-
SELECT時にカウントアップ
-
行方向のデータを横に並べる
-
商品コード番号を入力すると商...
-
select文の書き方
-
filemakerでのポータルの設定の...
-
Accessでフィールドを比較した...
-
VIEWでテーブルの集計結果...
-
Accessリレーションシップ
-
ACCESSのSQLで、NULLかNULLでな...
-
Accessにインポートしたら並び...
-
ACCESS2007 フォーム 「バリア...
-
主キーにインデックスは貼らな...
-
ACCESSのBookmarkプロパティの...
-
Accessでクエリを完了できませ...
-
MongoDBのデータ更新はDBを排他...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
2つのテーブルから条件に一致...
-
重複するキーから一番古い年月...
-
ACCESS 一つのフィールドに複...
-
行方向のデータを横に並べる
-
PLSQLの識別子エラー
-
VIEWでテーブルの集計結果...
-
Accessでフィールドを比較した...
-
Accessユニオンクエリーで2つ...
-
主キーの変更
-
ACCESSのコンパイルエラーについて
-
片方だけ抽出する方法(SQL)
-
【Access】順位を付けたい
-
[Oracle] UPDATE分の副問い合わ...
-
テーブル値関数経由でのデータ更新
-
ACCESS インポート時の重複チ...
-
ACCESS2000でDCount関数の使い方
-
Access2002の集計レポート?
-
商品コード番号を入力すると商...
-
Inner join と Left joinの明...
おすすめ情報