
オラクルSQLで質問です
やりたいことは、
テーブルAから以下の条件に該当するデータを削除する。
基本的にはテーブルBの内容と比較して、一致したもの。
条件(全ての条件を満たすこと)
テーブルA.AAA = テーブルB.AAA
テーブルA.BBB = テーブルB.BBB
テーブルB.CCC > 0
調べたところ、SQLサーバでは以下のように
from を2つ書いて実現できるようです。
が、今回はオラクルなので文法エラーになります。
delete FROM テーブルA FROM テーブルB
where
テーブルA.AAA = テーブルB.AAA
AND
テーブルA.BBB = テーブルB.BBB
AND
テーブルA.CCC > 0
;
commit;
よろしくお願いします
No.3ベストアンサー
- 回答日時:
delete 文の細かい構文はちょっと覚えてませんが
サブクエリ使えばいいんじゃないですか
delete from table_a
where 主キーカラム = (
select table_a.主キーカラム
from table_a, table_b
where
指定の条件
)
No.5
- 回答日時:
提示されているSQLサーバのSQLと同等の動作をするSQLは次のような感じです。
delete テーブルA a
where
a.CCC>0 and
exists(select 1 from テーブルB b where a.AAA=b.AAA and a.BBB=b.BBB)
;
または
delete テーブルA a
where
a.CCC>0 and
(a.AAA,a.BBB) in (select b.AAA,b.BBB from テーブルB b)
;
みなさん、ありがとうございます。まとめてですいません。
過去のQAを検索したところ以下のものがみつかり、
結局これを利用しました。
>BTABLEのCODEが1のレコードにKEYで関連付く
>ATABLEのレコードを削除
>DELETE FROM ATABLE WHERE
>( KEY1, KEY2 ) IN (
> SELECT KEY1, KEY2
> FROM BTABLE
> WHERE CODE=1
>)
まだSQLをはじめたばかりで、
みなさんからの回答もすぐには理解できないレベル
なのですが、また参考にさせてもらいます。
ありがとうございました。
No.4
- 回答日時:
いくつ主キーがあるのか分かりませんが・・・。
DELETE
FROM A
WHERE A.AAA = (
SELECT B.AAA
FROM B
WHERE A.AAA = B.AAA AND
A.BBB = B.BBB AND
B.CCC > 0
);
こんなんでどうでしょ。
見た目上、全角スペースを使っているのでコピペは厳禁。
No.2
- 回答日時:
delete文のどの辺りでエラーが出るのか教えてほしいかも。
テーブルAとテーブルBをカンマでつなげて書くとか?
つまり、
delete FROM tableA,tableB where ・・・・
とか、そんな感じではだめですかね?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
2つのテーブルに共通するレコードを削除したい
Access(アクセス)
-
EXISTSを使ったDELETE文
SQL Server
-
SQL 複数テーブルのupdate
Oracle
-
4
【SQL】他テーブルに含まれる値に合致する行を抽出
その他(データベース)
-
5
一致するデータのみ削除したい
MySQL
-
6
DELETE 文とEXISTSの使い方について(Oracle10g)
Oracle
-
7
SQLローダーCSV取込で、囲み文字がデータ中に入っている場合について
Oracle
-
8
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
9
SELECTで1件のみ取得するには?
Oracle
-
10
SQL文のwhere条件文で使う <> の意味はなんですか
その他(データベース)
-
11
GROUP BYを行った後に結合したい。
Oracle
-
12
SQLで特定の項目の重複のみを排除した全項目を取得する方法
その他(プログラミング・Web制作)
-
13
sqlplusで表示が変なので、出力を整形したい。
Oracle
-
14
テーブルからのselectにおいてデータの有無により結果をわけたい
PostgreSQL
-
15
複数の表の条件でのDELETE文
その他(データベース)
-
16
Oracle 2つのDate型の値の差を「分」で取得したい
その他(データベース)
-
17
AccessのRefresh・Requery・Repaintの違い
Access(アクセス)
-
18
Viewにインデックスは張れますか?
Oracle
-
19
count関数の値をwhere句で使用する方法について
MySQL
-
20
Access サブフォームでの選択行の取得
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
SQL、2つのテーブルで条件一致...
-
5
SQLでSUMなどの関数でデータが...
-
6
件数とデータを同時に取得する...
-
7
OracleのSQLで同テーブルのカラ...
-
8
特定のカラムが更新されたとき...
-
9
SQLサーバーでデータベース情報...
-
10
テーブル名をカラムとして取得...
-
11
ROWNUMでUPDATEをしたいのです...
-
12
SQLで違うテーブルの値を比較し...
-
13
カラム位置変更
-
14
Oracleのview、synonymをCOMPIL...
-
15
Oracle(オラクル)で、日付時刻...
-
16
update文で改行を入れる
-
17
DBからタブ区切りのCSVデータを...
-
18
PLSQLのバインド変数の件です。
-
19
CopyToClipboardからEXCELへPaste
-
20
PLSQLでフィールド名の参照につ...
おすすめ情報
公式facebook
公式twitter