「テーブルの特定の項目を、別のテーブルを参照した値で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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
好きなおでんの具材ドラフト会議しましょう
肌寒くなってきて、温かい食べ物がおいしい季節になってきましたね。 みなさんはおでんの具材でひとつ選ぶなら何にしますか? 1番好きなおでんの具材を教えてください。
-
一回も披露したことのない豆知識
あなたの「一回も披露したことのない豆知識」を教えてください。 「そうなんだね」と「確かに披露する場所ないね」で評価します。
-
「覚え間違い」を教えてください!
私はかなり長いこと「大団円」ということばを、たくさんの団員が祝ってくれるイメージで「大円団」だと間違えて覚えていました。
-
昨日見た夢を教えて下さい
たまにすごいドラマチックな夢見ること、ありませんか? 起きてからも妙に記憶に残っているような、そんな夢。
-
ギリギリ行けるお一人様のライン
おひとり様需要が増えているというニュースも耳にしますが、 あなたが「ギリギリ一人でも行ける!」という場所や行為を教えてください
-
UPDATE文のWHERE条件に他のテーブルのフィールドも入れたい
SQL Server
-
オラクルのUPDATEで複数テーブル
Oracle
-
PL/SQLでのTO_DATEの時間取得について
その他(プログラミング・Web制作)
-
-
4
CASE文のエラーについて
Oracle
-
5
はじめまして!
Oracle
-
6
ORA-01013のエラーについて経験のある方お願いします。
Oracle
-
7
TO_CHARでのゼロ非表示について
Oracle
-
8
NOT NULL制約がついた項目のUPDATEについて
Oracle
-
9
ROWNUMでUPDATEをしたいのですが・・・。
Oracle
-
10
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
11
SQLローダーCSV取込で、囲み文字がデータ中に入っている場合について
Oracle
-
12
PL/SQLのコンパイルエラーについて(ignored)
Oracle
-
13
テーブルの存在チェックについて
Oracle
-
14
SQL、2つのテーブルで条件一致したものだけdeleteする方法は?
Oracle
-
15
PL/SQLで@ファイル名が反応しません
Oracle
-
16
全角空白のTRIMができない・・・
Oracle
-
17
updateで複数行更新したい
Oracle
-
18
sql*loader 数値のロード
Oracle
-
19
PL/SQL PLS-00103エラーについて
Oracle
-
20
SQLPLUSで結果を画面に表示しない
Oracle
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
GROUP BYを行った後に結合した...
-
select insertで複数テーブルか...
-
SELECTの結果で同一行を複数回...
-
select句副問い合わせ 値の個...
-
テーブルの列名をデータとして...
-
MERGE文を単体テーブルに対して...
-
固定値を含む結合と複数テーブ...
-
SET句内で複数の条件を指定して...
-
複数テーブルのMAX値の行データ...
-
ある条件を持たないレコードの抽出
-
GROUP BY , MAX の使用法に関して
-
他のテーブルを参照した値はupd...
-
外部結合とor条件混在の記述方法
-
unionの結果は集計はできないで...
-
構成比を求めるSQL文につきまして
-
unionでマージした副問合せを結合
-
副問い合わせのinsert文
-
oracleの分割delete
-
COUNTの取得方法(?)について...
-
SQL GROUPで件数の一番多いレコ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
GROUP BYを行った後に結合した...
-
select insertで複数テーブルか...
-
select句副問い合わせ 値の個...
-
SELECTの結果で同一行を複数回...
-
固定値を含む結合と複数テーブ...
-
MERGE文を単体テーブルに対して...
-
複数テーブルのMAX値の行データ...
-
他のテーブルを参照した値はupd...
-
外部結合とor条件混在の記述方法
-
oracleの分割delete
-
SQLの書き方(チェックボックス)
-
SET句内で複数の条件を指定して...
-
unionの結果は集計はできないで...
-
unionでマージした副問合せを結合
-
SQL GROUPで件数の一番多いレコ...
-
集計後の数値が倍になる
-
結合と副問い合わせの違い
-
DELETE 文とEXISTSの使い方につ...
-
マテビューのNOTNULL設定について
-
副問い合わせのinsert文
おすすめ情報