![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
「テーブルの特定の項目を、別のテーブルを参照した値でupdateできない」問題で悩んでいます。
以下の2つのテーブルがある場合、
select * from TAB_A
COL001 COL002 COL003
------ ------ ------
00001 YYY DE
00002 YYY FG
00003 YYY HI
select * from TAB_B
COL001 COL002 COL003
------ ------ ------
00001 YYY ST
00002 YYY UV
00003 YYY WX
TAB_AのCOL01とCOL02 を条件に TAB_BのCOL03を検索して、TAB_AのCOL03を更新するために
update TAB_A set TAB_A.COL003 = (
select TAB_B.COL003
from TAB_A,TAB_B
where TAB_A.COL01 = TAB_B.COL01 and
TAB_A.COL02 = TAB_B.COL02 )
と、記述すると、
ORA-01427: 単一行副問合せにより2つ以上の行が返されます。
とのメッセージが表示される場合があります。
なにか良い解決策はあるでしょうか?
「SQLは、実はテーブルの特定の項目を、別のテーブルを参照した値でupdateできない」のだ、との噂も聞きますが....
なお、使用しているDBは Oracle10gです。
No.1ベストアンサー
- 回答日時:
相関問い合わせでの更新は、UPDATE対象の表の更新レコードに対応する1件を返す副問い合わせ文を
書かないといけないのですが、副問い合わせ文の中で、更新表をFROMに書いてしまうと、更新表と
無関係の副問い合わせを行ってしまいます。
update TAB_A set TAB_A.COL003 = (
select TAB_B.COL003
from TAB_B /* <============================注目 */
where TAB_A.COL01 = TAB_B.COL01 and
TAB_A.COL02 = TAB_B.COL02 )
のようにすれば、問題なく動作するかと思いますよ。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excel 、この式はどのように解釈すればいいのでしょうか 4 2023/02/03 08:53
- Oracle SQL update方法 2 2022/06/22 14:07
- HTML・CSS CSS のみのタブ切り替えについて 1 2023/01/11 16:47
- その他(コンピューター・テクノロジー) Pythonの np.indicesに関する質問です。 2 2023/02/07 08:19
- フリーソフト AutoHotKey 「Tabを押し続ける → 右クリックを押し続ける」は出来る?? 2 2023/05/05 14:36
- Visual Basic(VBA) Excel VBAシートの色を一気に変える方法 1 2022/03/27 23:24
- マウス・キーボード Tabキーとテンキーが右側にあるワイヤレスキーボード を探しています。 仕事上数字を入力することが多 3 2022/09/22 21:13
- その他(パソコン・スマホ・電化製品) Switch スマートフォンへ送る できない 1 2023/04/01 22:57
- 楽器・演奏 TAB譜について 5 2023/04/18 19:52
- モニター・ディスプレイ Win11マルチディスプレイでの異なる仮想デスクトップの表示 3 2023/02/01 10:02
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
オラクルのUPDATEで複数テーブル
Oracle
-
UPDATE文のWHERE条件に他のテーブルのフィールドも入れたい
SQL Server
-
updateで複数行更新したい
Oracle
-
-
4
ROWNUMでUPDATEをしたいのですが・・・。
Oracle
-
5
はじめまして!
Oracle
-
6
PL/SQLのコンパイルエラーについて(ignored)
Oracle
-
7
PL/SQLで@ファイル名が反応しません
Oracle
-
8
SQL*Loaderで、データを加工してロードしたいです。
Oracle
-
9
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
10
SQL>UPDATEと同時にその件数をCOUNTする方法
その他(データベース)
-
11
Oracle 2つのDate型の値の差を「分」で取得したい
その他(データベース)
-
12
SQL Plusで項目名が最後まで表示されない?
Oracle
-
13
PL/SQLでのTO_DATEの時間取得について
その他(プログラミング・Web制作)
-
14
SQL、2つのテーブルで条件一致したものだけdeleteする方法は?
Oracle
-
15
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
16
NOT NULL制約がついた項目のUPDATEについて
Oracle
-
17
キーが同じを複数行を1行にまとめるには?
Oracle
-
18
SQL*LoaderでCSVから指定した列のみインポートしたい。
Oracle
-
19
単一グループのグループ関数ではありません。
Oracle
-
20
データの先頭文字の置換
Oracle
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
GROUP BYを行った後に結合した...
-
SELECTの結果で同一行を複数回...
-
固定値を含む結合と複数テーブ...
-
select句副問い合わせ 値の個...
-
select insertで複数テーブルか...
-
SQL GROUPで件数の一番多いレコ...
-
unionの結果は集計はできないで...
-
複数テーブルのMAX値の行データ...
-
updateの一括実行
-
SET句内で複数の条件を指定して...
-
副問い合わせのinsert文
-
unionでマージした副問合せを結合
-
COUNTの取得方法(?)について...
-
構成比を求めるSQL文につきまして
-
Left Joinについて
-
和集合と積集合の違いが知りた...
-
MERGE文を単体テーブルに対して...
-
SQL初心者のため、初歩的な質問...
-
オラクル 外部結合についての質問
-
Oracleでの文字列連結サイズの上限
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
GROUP BYを行った後に結合した...
-
select句副問い合わせ 値の個...
-
select insertで複数テーブルか...
-
SELECTの結果で同一行を複数回...
-
MERGE文を単体テーブルに対して...
-
他のテーブルを参照した値はupd...
-
SET句内で複数の条件を指定して...
-
固定値を含む結合と複数テーブ...
-
SQL GROUPで件数の一番多いレコ...
-
oracleの分割delete
-
外部結合とor条件混在の記述方法
-
unionの結果は集計はできないで...
-
複数テーブルのMAX値の行データ...
-
unionでマージした副問合せを結合
-
集計後の数値が倍になる
-
構成比を求めるSQL文につきまして
-
COUNTの取得方法(?)について...
-
SQLの書き方(チェックボックス)
-
結合と副問い合わせの違い
-
DELETE 文とEXISTSの使い方につ...
おすすめ情報