• ベストアンサー

SQLで他のテーブルを参照して該当個所を一発更新したい

例えば次のような二つのテーブルがあるとします。 住所録(氏名,住所,メモ) 電話帳(氏名,電話番号) ※(住所録の氏名はキーだが電話帳の氏名はキーではない) この時、住所録テーブルに対して、 電話帳に電話番号がない名前全てについて メモに、"電話番号は不明"と言う更新をしたいのですが… UPDATE 住所録 SET メモ='電話番号は不明' WHERE … のWHERE句には何と書けばいいのか分からなくて困っています。 それともこういう時の更新はそもそも出来ないのでしょうか? 回答よろしくお願いします。

noname#6248
noname#6248

質問者が選んだベストアンサー

  • ベストアンサー
  • stork
  • ベストアンサー率34% (97/285)
回答No.3

使用のDBを書きましょう。 SQLserverと仮定します。 update (住所録、電話帳) set 電話帳.メモ = '電話番号は不明' from 住所録 left outer join 電話帳    on 住所録.氏名 = 電話帳.氏名 where 電話帳.氏名 is null かな? 元専門家より

その他の回答 (3)

  • nao_cat
  • ベストアンサー率0% (0/1)
回答No.4

NOT EXISTSを使用してみてはいかがでしょう? “EXISTS:条件に合致するものがある”のNOTでWHEREを…(詳しくは下記参照) UPDATEではなくDELETEで使用したことならあります。 UPDATEで使用できるかは保証しかねますけどね… UPDATE SET メモ='電話番号は不明' FROM 住所録 X WHERE NOT EXISTS (SELECT * FROM 電話帳 Y WHERE Y.氏名=X.氏名)

  • hidearex
  • ベストアンサー率25% (87/346)
回答No.2

No.1です。少し気になったのですが、なぜ電話番号と住所を別のテーブルに分けてるのでしょうか? ひとつのテーブルにした方が扱いやすいと思うし 二つに分けなきゃいけない理由というのが想定できません。。。 差支えなければ教えていただけますか?

noname#6248
質問者

お礼

実際のテーブルは複雑なので例として挙げているだけです(半分嘘) 他テーブルを参照し、かつNOT条件でUPDATEが可能かを知りたかったので… 当然ですが名前はキーとなりえませんよね(同姓同名があれば)で… すみません(^_^;)これくらいで勘弁願えませんか? ですから実際に使う時は以下のようなのです。 某テーブル(A)があり、それにぶら下がるテーブル(B)が存在して… (A)に削除フラグを立てる際に(B)テーブルにフラグを立てるための従属データがある時は削除フラグを立てられない…と言う内容にするのにアクセス回数が減らせないか…と言う質問でした。守秘義務ギリギリ…(大汗) 以上です。

  • hidearex
  • ベストアンサー率25% (87/346)
回答No.1

うろ覚えで申し訳ないのですが、UPDATE文も副問合せ使用できましたよね。。。 UPDATE 住所録 SET メモ='電話番号は不明' WHERE 氏名.住所録=in(select 氏名 from 電話帳 WHERE 電話番号 is null) で、どうでしょう? *住所録テーブルと電話帳テーブルとの間のデータの整合性が気になりますが。。。

関連するQ&A

  • SQLを使って他のテーブルから更新したいのですが

    状況説明 テーブル:顧客→マスターファイルで住所や電話がブランク テーブル:NewTable→住所や電話番号でデータを持っている NewTableの内容を顧客テーブルに更新したい SQL→ UPDATE 顧客 INNER JOIN NewTable ON 顧客.店舗名 = NewTable.店舗名 SET 顧客.客室数 = NewTable.客室数, 顧客.郵便番号 = NewTable.郵便番号, 顧客.都道府県 = NewTable.住所, 顧客.店電話 = NewTable.電話番号, 顧客.店FAX = NewTable.FAX NO, 顧客.オープン日 = NewTable.オープン日; 実行方法→ これが正しいかどうか分からないのですが、 モジュールのオブジェクトを選んで 新規作成を選ぶとVBモードになります。 ここでイミディエイト画面を出して 上記のSQLをそのまま入れ、 実行のため、Enterキーをたたいたら エラーが発生→ コンパイラエラー 修正候補:ステートメントの最後 と出ました。 質問→ そもそもSQLの実行をイミディエイト画面からでいいのかも わかりません 何かアドバイスいただけますでしょうか

  • SQLで複数のテーブルと結合した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を使っています。

  • 1テーブル&複数レコードの更新に対して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…[住所]、[氏名]、[電話番号]、[携帯番号]、[変更日] テーブルB…[氏名]、[自宅電話・携帯番号]、[変更日] Bの[氏名]と[自宅電話・携帯番号]が、Aの[氏名]と[電話番号]、[携帯番号]に一致した場合、Aの[変更日]がBの[変更日]に更新されるようにしたいです。 以前、似たような質問で回答して頂いたのですが、条件が二つになり指定方法が上手くいかなくなってしまいました。 お手数お掛けしますが回答宜しくお願いします。

  • アクセスでテーブルの一部を他テーブルを使って更新をしたい

    [ユーザーリスト]というテーブルがあり、その中にはユーザー名、住所、電話番号などが入っています。 後から電話番号の更新があったユーザーを修正するために、新しい電話番号とユーザー名だけが入っている[更新リスト]というテーブルを使って、[ユーザーリスト]の電話番号だけを一括で修正することはできるのでしょうか。 わかりにくい説明で申し訳ありませんが、ご回答の方宜しくお願いします。

  • ExcelVBAからAccess更新のSQL

    お世話になります。 ExcelVBAからAccessDBを更新するソースを書いています。 外部データMDBを取得するマクロを記録し、SQL文をUPDATEに変更しているのですが、更新されません。 a = "UPDATE `C:\Documents and Settings\User\デスクトップ\sample`.住所テーブル 住所テーブル" & Chr(13) & "" & Chr(10) & "SET 住所テーブル.氏名 = 'b'" .CommandText = Array(a) このaをAccessのクエリで実行すると更新されますが、Excelからだと更新できません。 Commitしてないからでしょうか? ヘルプで検索してもCommittransメソッドと検索されるのですが、右側に内容が表示されません・・・。 ご存知の方、ご教授願います。 情報が足らないなどもお願いします。

  • SQL で更新(update)

    SQLのupdate文で質問です。 こんな感じに更新したいんですが、 行番号が1のときの数値を行番号2も同じにしたいんですが、ちなみちに品番ごとです。 データはW_iテーブルのデータをそのまま更新したいんですが、どのようにしたろうまく出来ますか。 update W_i set 値 = 数値 from W_i where 行番号 = '1' こうすると行番号1しか変わらない (初期)        品番 数値 行番号 ------------------ CZ 5 1 CZ 8 2 DF 6 1 DF 3 2 ↓ (更新後) 品番 数値 行番号 ----------------- CZ 5 1 CZ 5 2 DF 6 1 DF 6 2

  • 更新クエリでテーブルを書き換えたい

    データが0件のテーブルに、更新クエリで一つのレコードを追加したいのですが そもそもテーブルにデータが入ってない状態だから更新すらできないのですが こういう時どうすればいいでしょうか? Ttest01テーブルにaを入れたい場合、 UPDATE Ttest01 SET Ttest01.test01 = "a"; これだとうまくできません。 Ttest01のtest01フィールドの1行目にaを入れる方法を教えてください。

  • accessのVBAでテーブル更新するには・・・?

    [input]フォームより「登録」ボタンを押すことで [data]テーブルの[氏名][住所][電話番号][年齢][性別][コメント]フィールドを更新する動作をVBAだけでさせたいです。 このボタンだけで新規登録と更新登録ように既存データの氏名と住所を参照して入力されたデータが既存なのかを確認するようにしたいです。 dim dbs as database をつかってSQLを書き込んでいけばいけるような気がするのですが どうもうまくいきません。 よろしくお願いします。

  • 他テーブルの区分を使っての集計に関して

    教えて下さい。 AとBというテーブルが存在し、それぞれ Aテーブル 社員番号、金額 Bテーブル 社員番号、部署コード という項目となっています。 ※ かなり簡単なテーブルに省略してありますが、、、、 上記のBテーブルの部署コード毎にAテーブルの金額を集計したいと考えていますが、 そのようなSQLはどのように書くのでしょうか。。。 単純にfrom句で2つのテーブルを指定し、where句で社員番号で結合し、group by で部署コードを指定してもできなかったものですから。。。 初歩的な質問で申し訳ありませんが、教えて頂ければ幸いです。 よろしくお願いします。