
オラクル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で質問しましょう!
似たような質問が見つかりました
- SQL Server ACCESSで複数テーブルを結合して、リストを作る方法を教えてください。 2 2022/08/12 19:32
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- Oracle SQL update方法 2 2022/06/22 14:07
- SQL Server ACCESSで3ファイルを結合して、表を作成するやり方を教えて下さい。 17 2022/08/15 20:34
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
- Oracle sqlのupdate文で質問です。 テーブルBの番号をキーにテーブルAの身長をテーブルBの身長に更新 2 2022/11/02 15:15
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- Oracle sqlで質問です。 Aテーブルの情報をBテーブルに更新かけたいです。 やりたいことは、Bテーブルの受 1 2023/05/17 11:17
- MySQL 複数DBテーブルからのデータ取得 3 2022/05/17 15:02
- その他(Microsoft Office) パワークエリの複数ファイルのデータ統合について 3 2022/07/14 17:06
このQ&Aを見た人はこんなQ&Aも見ています
-
EXISTSを使ったDELETE文
SQL Server
-
2つのテーブルに共通するレコードを削除したい
Access(アクセス)
-
一致するデータのみ削除したい
MySQL
-
-
4
【SQL】他テーブルに含まれる値に合致する行を抽出
その他(データベース)
-
5
2つのテーブルを比較して一致した行を除外して表示するクエリ
その他(データベース)
-
6
UPDATE文のWHERE条件に他のテーブルのフィールドも入れたい
SQL Server
-
7
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
8
複数の表の条件でのDELETE文
その他(データベース)
-
9
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
10
データを削除しても表領域の使用率が減りません
Oracle
-
11
SQLローダーCSV取込で、囲み文字がデータ中に入っている場合について
Oracle
-
12
INSERT文でフィールドの1つだけを他のテーブルから取ってきた値を入れたい
その他(データベース)
-
13
異なるスキーマからデータを抽出するには?oracl、PL/SQL
Oracle
-
14
単一グループのグループ関数ではありません。
Oracle
-
15
SQLPLUSで結果を画面に表示しない
Oracle
-
16
select句副問い合わせ 値の個数が多すぎます
Oracle
-
17
SQL*Loaderでのsysdate使用
Oracle
-
18
GROUP BYを行った後に結合したい。
Oracle
-
19
Viewにインデックスは張れますか?
Oracle
-
20
別テーブルからSELECTした値を持つ行を削除するSQLは?
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テーブル名をカラムとして取得...
-
SQLでSUMなどの関数でデータが...
-
OracleのSQLで同テーブルのカラ...
-
SQL、2つのテーブルで条件一致...
-
sqlplusで表示が変なので、出力...
-
SQL 複数テーブルのupdate
-
DELETE文とロックについて
-
数値をNUMBER型にするかCHAR型...
-
SQL(oracle)でご助言いただきた...
-
SQL*LoaderでCSVから指定した列...
-
半角英数文字の抽出がしたい。
-
SQLで違うテーブルの値を比較し...
-
SQLでデータを1件だけ取得した...
-
カラム位置変更
-
ROWNUMでUPDATEをしたいのです...
-
DBからタブ区切りのCSVデータを...
-
Oracleのview、synonymをCOMPIL...
-
update文で改行を入れる
-
あるテーブルだけをキャッシュ...
-
Viewのカラムの長さが不明?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SQL、2つのテーブルで条件一致...
-
update文で改行を入れる
-
SQL*LoaderでCSVから指定した列...
-
sqlplusで表示が変なので、出力...
-
テーブル名をカラムとして取得...
-
SQL 複数テーブルのupdate
-
ROWNUMでUPDATEをしたいのです...
-
カラム位置変更
-
SQLでSUMなどの関数でデータが...
-
SQL(oracle)でご助言いただきた...
-
OracleのSQLで同テーブルのカラ...
-
SQLで違うテーブルの値を比較し...
-
特定のカラムが更新されたとき...
-
LONG型の先頭250バイトを Varch...
-
DBからタブ区切りのCSVデータを...
-
Viewのカラムの長さが不明?
-
distinct をexistsに変換する
-
oracle 複数列を1列にまとめる
-
件数とデータを同時に取得する...
-
数値をNUMBER型にするかCHAR型...
おすすめ情報