質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

3回答

1623閲覧

一方のテーブルから、もう一方のテーブルと重複したものを削除したい。

good_morning

総合スコア61

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2019/04/03 23:06

編集2019/04/03 23:13

現在、sql文を使ってテーブルの加工をしています。
そして、一方のテーブルから、もう一方のテーブルと重複したものを削除することになりました。
そのテーブル例は次の通りです。

イメージ説明

左のテーブルをa、右のテーブルをbとします。
つまり、aの中から、bと重複する001,002,005,010を削除して006だけにしたいということです。
そのために作成したsql文が次のとおりです。

sql

1delete from a 2where a.var_1 = (select a.var_1 from a, b where a.var_1 = b.var_1)

しかし、こうすると次のエラーが出ました。

【エラーメッセージ】
ERROR: 複数の行に対して、サブクエリが評価されます。

上記の目的を達成するには、どうしたらよろしいでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

=だと単一という意味合いになるので、サブクエリーが複数行を返すのでエラーです。
Inを使用して下さい。

SQL

1delete from a 2where a.var_1 in (select a.var_1 from a, b where a.var_1 = b.var_1)

また、この要件だと性能的にはExistsによる相関を使用した方が高速だと思います。

SQL

1delete from a 2where exists(select 1 from b where var_1 = a.var_1)

投稿2019/04/04 00:13

編集2019/04/04 00:16
sazi

総合スコア25138

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

good_morning

2019/04/04 04:39

ありがとうございました。うまくいきました。
guest

0

ベストアンサー

エラーの内容としては副問い合わせの結果が複数行出てきているので'='では評価できない。
ということです。

一般SQLとしての回答になりますが、IN句を使えばよいかと。

SQL

1DELETE 2FROM a 3WHERE a.var_1 IN 4 (SELECT b.var_1 5 FROM b);

投稿2019/04/03 23:41

編集2019/04/03 23:42
mackerel6.023

総合スコア317

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

good_morning

2019/04/04 04:39

ありがとうございます。とてもシンプルです。
guest

0

同じSQLでもデータベースによって方言が大きいですから、どのデータベースを使うのかを質問のタグで明示したり、バージョンも明記した方が適切なコメントが付き易いです。 SQLの観点から Oracle Database, PostgreSQL, MySQL の特徴を整理しよう!

SQL

1select a.var_1 from a, b where a.var_1 = b.var_1 order by a.var_1

SQL

1select distinct a.var_1 from a, b where a.var_1 = b.var_1 order by a.var_1

の結果を質問に追記してください。

SQL

1delete from a 2where a.var_1 = (select distinct a.var_1 from a, b where a.var_1 = b.var_1)

で動作するでしょうか?

投稿2019/04/03 23:14

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

good_morning

2019/04/03 23:28

回答ありがとうございます。ただし、sqlに関してはSASのsqlなので、oracleとか一般のDBではありません。よろしくお願いします。
Orlofsky

2019/04/04 00:06

SASならそれを質問に明記して、必要なら新規にタグの追加を依頼してください。 SASって独自のデータベースを持っていたでしょうか?SAS/ACCESSで各データベースのSQLの方言を吸収するっていうインターフェイス程度の知識しかありません。 回答のSQLの実行結果はどうなりましたか?
good_morning

2019/04/04 04:39

サンプル、ありがとうございました。上記1,2ともにうまくいきました。ただし、3は削除すべきデータが残ってしまいました。
Orlofsky

2019/04/04 06:40

サブクエリでINを使うべきでしたね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問