SQL に関する質問です。

あるテーブルA にある uidのうち、他のテーブルBに存在する uid があったらそのuid を削除したいのです。
単純なので簡単にかけるはずですが、delete from a where b なんとか だと思います。
こういったちょっとテーブル間操作(単純な集合演算)をするSQL文を書こうとすると参考になるページが簡単に見つかりません。
上記の例も含めて、よくありえる集合演算に関して、まとまったページがあったら教えてください。ベン図を書いてすぐに指示できるような集合演算をSQLで書こうとすると結構面倒です。
(たまにしか書かないので、すぐ文法を忘れてしまいます。)
SQLは、MySQL のがありがたいです。
詳細に書いてあるのはあるようですが、詳細に書いてあるのは読む気がしません。

回答の条件
  • URL必須
  • 1人2回まで
  • 登録:2008/05/02 16:15:38
  • 終了:2008/05/09 16:20:03

回答(1件)

id:Mook No.1

Mook回答回数1312ベストアンサー獲得回数3912008/05/02 18:48:19

ポイント60pt

下記のようなSQLでどうでしょうか。

DELETE FROM a WHERE uid IN ( SELECT DISTINCT uid FROM B )

MySQL でのサブクエリは バージョン4以降で利用可能だったと思います。

http://dev.mysql.com/doc/refman/4.1/ja/subqueries.html

  • id:chuken_kenkou
    MySQLでのサブクエリの実装は、MySQL 4.1以降です。
    お使いのバージョンを、提示してください。

この質問への反応(ブックマークコメント)

「あの人に答えてほしい」「この質問はあの人が答えられそう」というときに、回答リクエストを送ってみてましょう。

これ以上回答リクエストを送信することはできません。制限について

絞り込み :
はてなココの「ともだち」を表示します。
回答リクエストを送信したユーザーはいません