例えば次のような二つのテーブルがあるとします。
住所録(氏名,住所,メモ)
電話帳(氏名,電話番号)
※(住所録の氏名はキーだが電話帳の氏名はキーではない)
この時、住所録テーブルに対して、
電話帳に電話番号がない名前全てについて
メモに、"電話番号は不明"と言う更新をしたいのですが…
UPDATE 住所録 SET メモ='電話番号は不明' WHERE …
のWHERE句には何と書けばいいのか分からなくて困っています。
それともこういう時の更新はそもそも出来ないのでしょうか?
回答よろしくお願いします。
No.3ベストアンサー
- 回答日時:
使用のDBを書きましょう。
SQLserverと仮定します。
update (住所録、電話帳)
set 電話帳.メモ = '電話番号は不明'
from 住所録 left outer join 電話帳
on 住所録.氏名 = 電話帳.氏名
where 電話帳.氏名 is null
かな?
元専門家より
No.4
- 回答日時:
NOT EXISTSを使用してみてはいかがでしょう?
“EXISTS:条件に合致するものがある”のNOTでWHEREを…(詳しくは下記参照)
UPDATEではなくDELETEで使用したことならあります。
UPDATEで使用できるかは保証しかねますけどね…
UPDATE
SET
メモ='電話番号は不明'
FROM
住所録 X
WHERE
NOT EXISTS (SELECT * FROM 電話帳 Y WHERE Y.氏名=X.氏名)
No.2
- 回答日時:
No.1です。
少し気になったのですが、なぜ電話番号と住所を別のテーブルに分けてるのでしょうか?ひとつのテーブルにした方が扱いやすいと思うし
二つに分けなきゃいけない理由というのが想定できません。。。
差支えなければ教えていただけますか?
実際のテーブルは複雑なので例として挙げているだけです(半分嘘)
他テーブルを参照し、かつNOT条件でUPDATEが可能かを知りたかったので…
当然ですが名前はキーとなりえませんよね(同姓同名があれば)で…
すみません(^_^;)これくらいで勘弁願えませんか?
ですから実際に使う時は以下のようなのです。
某テーブル(A)があり、それにぶら下がるテーブル(B)が存在して…
(A)に削除フラグを立てる際に(B)テーブルにフラグを立てるための従属データがある時は削除フラグを立てられない…と言う内容にするのにアクセス回数が減らせないか…と言う質問でした。守秘義務ギリギリ…(大汗)
以上です。
No.1
- 回答日時:
うろ覚えで申し訳ないのですが、UPDATE文も副問合せ使用できましたよね。
。。UPDATE 住所録
SET メモ='電話番号は不明'
WHERE 氏名.住所録=in(select 氏名 from 電話帳 WHERE 電話番号 is null)
で、どうでしょう?
*住所録テーブルと電話帳テーブルとの間のデータの整合性が気になりますが。。。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(Microsoft Office) EXCELの1行を1枚の用紙にそれぞれ印刷したい。 3 2022/10/10 11:35
- 料理教室 公園の休憩テーブルの上に 住所入りの段ボールの粗大ゴミが!? 3 2022/05/04 12:51
- メルカリ メルカリ本人確認について メルカリの本人確認 住所、氏名、電話番号、生年月日登録必要かと思います 友 2 2022/03/27 23:54
- 銀行・ネットバンキング・信用金庫 キャッシュカードの悪用 6 2022/06/12 10:57
- 郵便・宅配 アプリで口座登録をしてキャッシュカードが届き印鑑届を提出するのですが、印鑑届を入れる封筒があり、その 1 2022/11/15 14:59
- 防犯・セキュリティ 私のケータイ番号が、何者かによって 付箋メモ帳に書かれ 色んな所に貼られているそうです。 知らない番 1 2022/09/22 00:52
- Oracle sqlのupdate文で質問です。 テーブルBの番号をキーにテーブルAの身長をテーブルBの身長に更新 2 2022/11/02 15:15
- 事故 免許証 2 2022/05/17 00:00
- docomo(ドコモ) 携帯新規契約 TCA審査について 3 2022/06/17 14:02
- 銀行・ネットバンキング・信用金庫 ATネットバンク窓口 1 2023/05/05 00:57
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
お金持ちのテーブル
-
会社の飲み会の幹事になり、座...
-
「テーブルに座って……」という...
-
外部キーだけのテーブル(主キ...
-
テーブルリンク リンク元を知...
-
複数テーブルにわたるCOUNT
-
L2SWはARPテーブルを持っている?
-
MySQLで複数テーブルを作成する
-
テーブル所有者、スキーマ所有...
-
SQL 外部結合
-
包丁が危険
-
アクセスのリンクテーブル一覧...
-
MACアドレス見えない
-
論理名とコメント構文(?)について
-
【PHP】SQL文のSUM関数で出力し...
-
【SQL】グループ化した際の最頻...
-
テーブルの白く剥がれてるところに
-
ダイニングテーブルの真上に来...
-
まるいテーブル 円い 丸い 漢字...
-
リレーションシップが出来ません。
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
会社の飲み会の幹事になり、座...
-
テーブルリンク リンク元を知...
-
L2SWはARPテーブルを持っている?
-
テーブルの白く剥がれてるところに
-
飲み会で、座敷orテーブルどち...
-
まるいテーブル 円い 丸い 漢字...
-
1つのテーブルに同じデータを参...
-
このテーブルで
-
置き配された食べ物を袋からど...
-
外部キーだけのテーブル(主キ...
-
【PHP】SQL文のSUM関数で出力し...
-
「テーブルに座って……」という...
-
男性と2人で飲食店に行きテーブ...
-
アクセスのリンクテーブル一覧...
-
一致するデータのみ削除したい
-
論理名とコメント構文(?)について
-
ACCESSで3ファイルを結合して、...
-
MySQLで複数テーブルを作成する
-
複数テーブルにわたるCOUNT
-
SQL 外部結合
おすすめ情報