例えば次のような二つのテーブルがあるとします。

住所録(氏名,住所,メモ)
電話帳(氏名,電話番号)
※(住所録の氏名はキーだが電話帳の氏名はキーではない)

この時、住所録テーブルに対して、
電話帳に電話番号がない名前全てについて
メモに、"電話番号は不明"と言う更新をしたいのですが…

UPDATE 住所録 SET メモ='電話番号は不明' WHERE …

のWHERE句には何と書けばいいのか分からなくて困っています。

それともこういう時の更新はそもそも出来ないのでしょうか?
回答よろしくお願いします。

A 回答 (4件)

使用のDBを書きましょう。


SQLserverと仮定します。

update (住所録、電話帳)
set 電話帳.メモ = '電話番号は不明'
from 住所録 left outer join 電話帳
   on 住所録.氏名 = 電話帳.氏名
where 電話帳.氏名 is null

かな?
元専門家より
    • good
    • 0

NOT EXISTSを使用してみてはいかがでしょう?



“EXISTS:条件に合致するものがある”のNOTでWHEREを…(詳しくは下記参照)
UPDATEではなくDELETEで使用したことならあります。
UPDATEで使用できるかは保証しかねますけどね…

UPDATE
SET
メモ='電話番号は不明'
FROM
住所録 X
WHERE
NOT EXISTS (SELECT * FROM 電話帳 Y WHERE Y.氏名=X.氏名)
    • good
    • 0

No.1です。

少し気になったのですが、なぜ電話番号と住所を別のテーブルに分けてるのでしょうか?

ひとつのテーブルにした方が扱いやすいと思うし
二つに分けなきゃいけない理由というのが想定できません。。。

差支えなければ教えていただけますか?
    • good
    • 0
この回答へのお礼

実際のテーブルは複雑なので例として挙げているだけです(半分嘘)
他テーブルを参照し、かつNOT条件でUPDATEが可能かを知りたかったので…
当然ですが名前はキーとなりえませんよね(同姓同名があれば)で…
すみません(^_^;)これくらいで勘弁願えませんか?
ですから実際に使う時は以下のようなのです。

某テーブル(A)があり、それにぶら下がるテーブル(B)が存在して…
(A)に削除フラグを立てる際に(B)テーブルにフラグを立てるための従属データがある時は削除フラグを立てられない…と言う内容にするのにアクセス回数が減らせないか…と言う質問でした。守秘義務ギリギリ…(大汗)
以上です。

お礼日時:2002/01/21 09:53

うろ覚えで申し訳ないのですが、UPDATE文も副問合せ使用できましたよね。

。。


UPDATE 住所録
SET メモ='電話番号は不明'
WHERE 氏名.住所録=in(select 氏名 from 電話帳 WHERE 電話番号 is null)

で、どうでしょう?
*住所録テーブルと電話帳テーブルとの間のデータの整合性が気になりますが。。。
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

関連するカテゴリからQ&Aを探す

このQ&Aを見た人が検索しているワード

このQ&Aと関連する良く見られている質問

Q他のテーブルを参照した値はupdateでsetできない?

「テーブルの特定の項目を、別のテーブルを参照した値で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です。

「テーブルの特定の項目を、別のテーブルを参照した値で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のCOL...続きを読む

Aベストアンサー

相関問い合わせでの更新は、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 )

のようにすれば、問題なく動作するかと思いますよ。

QSQLで複数のテーブルと結合したUPDATE文

普通のUPDATE文はUPDATEするテーブル名を一つ記入して
UPDATE テーブルA SET フィールドA = 値A WHERE テーブルA.フィールドB = 値B
みたいな感じですが、私のしたい事はと言うと
UPDATE テーブルA,テーブルB,テーブルC
SET A.フィールドA = 値A
WHERE テーブルA.フィールドA = テーブルB.フィールドB
AND テーブルB.フィールドB = テーブルC.フィールドC
AND テーブルB.フィールドD = 値D
AND テーブルC.フィールドE = 値E
という具合に複数のテーブルがUPDATEするテーブルA以外のところで、互いに条件で結ばれており、FROM句でUPDATEしないテーブル名まで宣言しないといけなくなっています。そもそもこういうFROM句を使うUPDATE文は実行可能かも不明です。どなたか解決策お願いいたします。ちなみに開発ソフトはVBAを使っています。

Aベストアンサー

SET句にもサブクエリを使えますよ。

UPDATE テーブルA
SET フィールドA = ( SELECT テーブルB.フィールドF
FROM テーブルB,テーブルC
WHERE テーブルB.フィールドB = テーブルC.フィールドC
AND テーブルB.フィールドD = 値D
AND テーブルC.フィールドE = 値E )
WHERE フィールドA = ( SELECT テーブルB.フィールドB
FROM テーブルB,テーブルC
WHERE テーブルB.フィールドB = テーブルC.フィールドC
AND テーブルB.フィールドD = 値D
AND テーブルC.フィールドE = 値E )

> VBAと言うと普通ACCESSですよね?
VBAからODBC経由でOracleやSQL Serverという例もあるので
一概にはAccessのみとはいえません。

Q1テーブル&複数レコードの更新に対して1度のupdate文での処理方法

1テーブル&複数レコードの更新に対して1度のupdate文での処理方法

Delphi2010+SQL SERVER 2005で開発しています。

update文で、
現在下のようにwhileで複数レコードに対して、
1回、1回、sqlを発行して、更新しています。
これを、一度のSQLの発行で処理できないものでしょうか?
更新テーブルは1つで、更新する項目も同じです。
更新するデータと、where句の条件が異なります。

もし可能なようでしたら、どうかご教授お願いします。

update table set A=1,B=2 where id=1
update table set A=2,B=3 where id=5
update table set A=9,B=99 where id=7
update table set A=5,B=10 where id=15
update table set A=1,B=10 where id=75

Aベストアンサー

ですか・・・。
じゃあWhileで発行するのをやめたらどうですか?

BEGIN TRAN
update table set A=1,B=2 where id=1;
update table set A=2,B=3 where id=5;
update table set A=9,B=99 where id=7;
update table set A=5,B=10 where id=15;
update table set A=1,B=10 where id=75;
COMMIT

まとめて実行・・・。

QSelect文で2つのフィールドを加算した結果を取得したい

Select文で2つのフィールドを加算した結果を取得したいと思います。しかし2つのフィールドのうち1つがNullの値だと残りのフィールドに値が入っていても空白(NULL?)で返ります。

[例]**********************************************
フィールドA:Null
フィールドB:300

SELECT フィールドA+フィールドB
FROM テーブルA

<Selectされた結果>
空白(何も表示されない。Null?)

[例]**********************************************

どのようにすれば、Nullでない値だけ取得できるでしょうか。

Aベストアンサー

SQL Server の場合は ISNULL() 関数を使います。

SELECT ISNULL(フィールドA,0) + ISNULL(フィールドB,0)
FROM テーブルA

Q複数テーブルのUPDATE

タイトルの通り、複数テーブルのUPDATEを行いたいと思っています。
私なりには、以下のようなコードでテーブルを作成しようとしましたが、作成できませんでした。 エラー内容としては、
update table_1, table_2 SET
のtable_1, が間違ってます的なエラーでした。

update table_1, table_2 SET
table_1.updatetime=getdate(),
WHERE
table_1.SeqNo = table_2.SeqNo
AND table_1.SeqNo = @SeqNo

以上、緊急の内容であったため、十分調べていない点があるかもしれませんが、何卒、ご存知の方ご教授お願い致します。

Aベストアンサー

update1文で複数表の更新は、SQL Serverでは未サポートです。
MySQLでは、サポートしているようですけど。

質問にあるupdateは、table_1だけ更新するようになっているようですが、table_2の更新部分を省略して書いただけでしょうか?

updateで他表とジョインした結果で1表を更新するといった書き方なら、「update ~ set ~ from ~ where ~」といった書き方はできます。

QUPDATE文のWHERE条件に他のテーブルのフィールドも入れたい

SQL文についてです。

表Aで列1と列2が'◎'のものについて、列3,列4,列5をそれぞれ'○','△','×'に更新したい場合は下記でOKだと思います。
UPDATE 表A
SET 列3 = '○', 列4 = '△', 列5 = '×'
WHERE 列1 = '◎' AND 列2 = '◎'

列1と列2をキーとして表Aと結合できる表Bが存在するとします。
条件に表Bの列6が'□'だった場合を追加したい時、どのような方法で行えば良いのでしょうか?
内部結合やWHERE EXISTSなどをいろいろ調べたのですが、SQL文に慣れていないためかうまくいきません。
初歩的な質問で申し訳ありませんが過去質問で参考になるものがなかったのでお願いします。

Aベストアンサー

UPDATE 表A
SET 列3 = '○', 列4 = '△', 列5 = '×'
WHERE 列1 = '◎' AND 列2 = '◎'
AND EXISTS
( SELECT 1 FROM 表B
WHERE 表B.列1 = 表A.列1
AND 表B.列2 = 表A.列2
AND 表B.列6 = '□' )
じゃだめですか。


人気Q&Aランキング

おすすめ情報