オラクル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も見ています
-
新NISA制度は今までと何が変わる?非課税枠の拡大や投資対象の変更などを解説!
少額から投資を行う人のための非課税制度であるNISAが、2024年に改正される。おすすめの銘柄や投資額の目安について教えてもらった。
-
一致するデータのみ削除したい
MySQL
-
2つのテーブルに共通するレコードを削除したい
Access(アクセス)
-
EXISTSを使ったDELETE文
SQL Server
-
-
4
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
5
【SQL】他テーブルに含まれる値に合致する行を抽出
その他(データベース)
-
6
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
7
複数のテーブルの項目を同時に削除したい
その他(データベース)
-
8
GROUP BYを行った後に結合したい。
Oracle
-
9
UPDATE文のWHERE条件に他のテーブルのフィールドも入れたい
SQL Server
-
10
別テーブルからSELECTした値を持つ行を削除するSQLは?
その他(データベース)
-
11
DELETE 文とEXISTSの使い方について(Oracle10g)
Oracle
-
12
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
-
13
複数の表の条件でのDELETE文
その他(データベース)
-
14
CASE文のエラーについて
Oracle
-
15
ROWNUMでUPDATEをしたいのですが・・・。
Oracle
-
16
「指定されたキャストは有効ではありません。」とエラーが出てしまいます。
Microsoft ASP
-
17
2つのテーブルから条件に一致しないデータ抽出
SQL Server
-
18
アクセスのエラー「クエリには出力フィールドが1つ以上必要です。」
その他(Microsoft Office)
-
19
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
20
Viewにインデックスは張れますか?
Oracle
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テーブル名をカラムとして取得...
-
update文で改行を入れる
-
SQLでSUMなどの関数でデータが...
-
SQL*LoaderでCSVから指定した列...
-
SQL 複数テーブルのupdate
-
SQL、2つのテーブルで条件一致...
-
ROWNUMでUPDATEをしたいのです...
-
Oracle(オラクル)で、日付時刻...
-
sqlplusで表示が変なので、出力...
-
SQLで違うテーブルの値を比較し...
-
sql(oracle)で質問です。 テ...
-
Oracleのview、synonymをCOMPIL...
-
OracleのSQLで同テーブルのカラ...
-
DELETE文とロックについて
-
改行コードの検出方法につきまして
-
特定のカラムが更新されたとき...
-
SQLの書き方を教えてください。
-
ワークテーブルって何?
-
oracle 複数列を1列にまとめる
-
件数とデータを同時に取得する...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テーブル名をカラムとして取得...
-
SQL、2つのテーブルで条件一致...
-
ROWNUMでUPDATEをしたいのです...
-
SQL 複数テーブルのupdate
-
update文で改行を入れる
-
sqlplusで表示が変なので、出力...
-
SQL*LoaderでCSVから指定した列...
-
SQLでSUMなどの関数でデータが...
-
特定のカラムが更新されたとき...
-
SQLで違うテーブルの値を比較し...
-
件数とデータを同時に取得する...
-
カラム位置変更
-
UPDATE文
-
DELETE文とロックについて
-
数値をNUMBER型にするかCHAR型...
-
半角英数文字の抽出がしたい。
-
テーブルやカラムの物理名のネ...
-
DBからタブ区切りのCSVデータを...
-
Oracleのview、synonymをCOMPIL...
-
SELECT文で指定桁数分抽出する...
おすすめ情報