
オラクル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も見ています
-
EXISTSを使ったDELETE文
SQL Server
-
2つのテーブルに共通するレコードを削除したい
Access(アクセス)
-
【SQL】他テーブルに含まれる値に合致する行を抽出
その他(データベース)
-
-
4
一致するデータのみ削除したい
MySQL
-
5
UPDATE文のWHERE条件に他のテーブルのフィールドも入れたい
SQL Server
-
6
2つのテーブルを比較して一致した行を除外して表示するクエリ
その他(データベース)
-
7
複数の表の条件でのDELETE文
その他(データベース)
-
8
異なるスキーマからデータを抽出するには?oracl、PL/SQL
Oracle
-
9
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
10
データを削除しても表領域の使用率が減りません
Oracle
-
11
INSERT文でフィールドの1つだけを他のテーブルから取ってきた値を入れたい
その他(データベース)
-
12
select句副問い合わせ 値の個数が多すぎます
Oracle
-
13
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
14
Oracleでの文字列連結サイズの上限
Oracle
-
15
単一グループのグループ関数ではありません。
Oracle
-
16
SQLPLUSで結果を画面に表示しない
Oracle
-
17
「タイプ初期化子が例外をスローしました」エラー何?
Visual Basic(VBA)
-
18
oracleの分割delete
Oracle
-
19
Viewにインデックスは張れますか?
Oracle
-
20
GROUP BYを行った後に結合したい。
Oracle
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
SQL、2つのテーブルで条件一致...
-
sqlplusで表示が変なので、出力...
-
update文で改行を入れる
-
カラム位置変更
-
LONG型の先頭250バイトを Varch...
-
Oracleのview、synonymをCOMPIL...
-
ワークテーブルって何?
-
SQLでSUMなどの関数でデータが...
-
SQL*LoaderでCSVから指定した列...
-
SQL 複数テーブルのupdate
-
別テーブルにあるデータを部分...
-
DBからタブ区切りのCSVデータを...
-
UPDATE文で、書き換えるデータ...
-
oracleのエラー(ORA-00932)の...
-
Oracle(オラクル)で、日付時刻...
-
DELETE文とロックについて
-
SQL文のCOUNTの戻り値は?
-
SQL(oracle)でご助言いただきた...
-
カラム情報(主キー、データ型、...
-
SQLで違うテーブルの値を比較し...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
update文で改行を入れる
-
SQL*LoaderでCSVから指定した列...
-
SQL、2つのテーブルで条件一致...
-
SQLでSUMなどの関数でデータが...
-
SQL 複数テーブルのupdate
-
テーブル名をカラムとして取得...
-
sqlplusで表示が変なので、出力...
-
ROWNUMでUPDATEをしたいのです...
-
SQL(oracle)でご助言いただきた...
-
カラム位置変更
-
件数とデータを同時に取得する...
-
OracleのSQLで同テーブルのカラ...
-
LONG型の先頭250バイトを Varch...
-
数値をNUMBER型にするかCHAR型...
-
特定のカラムが更新されたとき...
-
半角英数文字の抽出がしたい。
-
DBからタブ区切りのCSVデータを...
-
sqlで質問です。 aテーブルとb...
-
SQLについて教えて下さい。 主...
-
Oracleのview、synonymをCOMPIL...
おすすめ情報