
オラクル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
UPDATE文のWHERE条件に他のテーブルのフィールドも入れたい
SQL Server
-
5
データを削除しても表領域の使用率が減りません
Oracle
-
6
INSERT文でフィールドの1つだけを他のテーブルから取ってきた値を入れたい
その他(データベース)
-
7
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
8
SQLPLUSで結果を画面に表示しない
Oracle
-
9
select句副問い合わせ 値の個数が多すぎます
Oracle
-
10
2つのテーブルを比較して一致した行を除外して表示するクエリ
その他(データベース)
-
11
一致するデータのみ削除したい
MySQL
-
12
複数の表の条件でのDELETE文
その他(データベース)
-
13
Oracle 2つのDate型の値の差を「分」で取得したい
その他(データベース)
-
14
オラクルのUPDATEで複数テーブル
Oracle
-
15
CASE文のエラーについて
Oracle
-
16
異なるスキーマからデータを抽出するには?oracl、PL/SQL
Oracle
-
17
別テーブルからSELECTした値を持つ行を削除するSQLは?
その他(データベース)
-
18
単一グループのグループ関数ではありません。
Oracle
-
19
oracleの分割delete
Oracle
-
20
SQLで特定の項目の重複のみを排除した全項目を取得する方法
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
SQL(oracle)でご助言いただきた...
-
SQLでSUMなどの関数でデータが...
-
特定のカラムが更新されたとき...
-
半角英数文字の抽出がしたい。
-
テーブル名をカラムとして取得...
-
「テーブルに座って……」という...
-
飲み会で、座敷orテーブルどち...
-
AccessのSQL 部分一致したデー...
-
SQLでUPSERTを一度に複数行やる...
-
降順で並び替えて昇順で受け取...
-
外部キーだけのテーブル(主キ...
-
住所のDBテーブル、マスターの...
-
会社の飲み会の幹事になり、座...
-
Oracleのsystem表領域について
-
SELECT 文の NULL列は?
-
男性と2人で飲食店に行きテーブ...
-
C#で電卓のプログラムを組んで...
-
面接のときテーブルが正面に。...
-
SQLでテーブルの値を集計して、...
-
MySQL8にバージョンアップした...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
sqlplusで表示が変なので、出力...
-
SQL*LoaderでCSVから指定した列...
-
SQL、2つのテーブルで条件一致...
-
update文で改行を入れる
-
DBからタブ区切りのCSVデータを...
-
ROWNUMでUPDATEをしたいのです...
-
SQLでSUMなどの関数でデータが...
-
カラム位置変更
-
SQL(oracle)でご助言いただきた...
-
SQL 複数テーブルのupdate
-
テーブル名をカラムとして取得...
-
DELETE文とロックについて
-
LONG型の先頭250バイトを Varch...
-
SQLで違うテーブルの値を比較し...
-
特定のカラムが更新されたとき...
-
件数とデータを同時に取得する...
-
半角英数文字の抽出がしたい。
-
OracleのSQLで同テーブルのカラ...
-
数値をNUMBER型にするかCHAR型...
-
Viewのカラムの長さが不明?
おすすめ情報