KoReKuRai
英語/転職海外/国内旅行健康MENU

MS Access 2016 UPDATEでJOINした時のエラー対処法「更新可能なクエリであることが必要です。」

clock
twitter
facebook
googleplus
line
line
line
sql

2つのテーブルをJOINしてUPDATE(更新)しようとしたら「更新可能なクエリであることが必要です」のクエリエラーが発生しました。

 クエリは以下の通りで全く問題無いです。何が問題なのか調べてみたら分かりました。


UPDATE TableA 
INNER JOIN TableB ON TableA.id = TableB.id 
SET TableA.name = TableB.name;

やりたいこと

下記にある2つのテーブル(TableAとTableB)をid列でJOINして、TableAのname列をTableBのname列にある値で置き換えたい。

※TableBはExcelファイルのリンクテーブルを元に作成したSELECTクエリです。

TableAのデータは以下の通りです。

  1. id, name, date
  2. 1, abc, 2016/1/1
  3. 2, def, 2016/1/2
  4. 3, ghi, 2016/1/3
  5. ...

TableBのデータは以下の通りです。

  1. id, name, code
  2. 2, def, 1583929
  3. 4, klm, 9484739
  4. 8, nop, 5758498
  5. ...

 

エラーの原因

クエリデザインで作成したリンクテーブルのSELECTクエリをJOINすることができないみたいです。

SELECTクエリがダメということなので、わざわざテーブルを用意してそこにデータを流し込みます。 その新規作成したテーブルをJOINさせたらエラー無くUPDATEができました。不便。

クエリは以下の通りです。この手順でUPDATEは出来ましたが、テーブル同士のJOINじゃないとUPDATEしてくれないので1つステップが余計に必要になります。


1.SELECT * INTO TableC FROM TableB(TableBのSELECTクエリの結果をTableCに入れます)
2.UPDATE TableA INNER JOIN TableB ON TableA.id = TableB.id SET TableA.name = TableB.name;(再度UPDATE文を実行)

 

スポンサーリンク

関連記事


twitter
facebook
googleplus
line
line
line
上へ
スポンサーリンク

月間ランキング



上へ
こんな記事も読まれてます。

TRAVEL JAPAN
国内旅行 記事一覧

屋久島の雨の日の空気ががおいしい伊豆下田の海はとてもきれいでした富士山の頂上でご来光スマホで見れる京都の観光マップです京都 紅葉とライトアップスマホで見れる富士山周辺観光マップ北海道の知床の絶景

TRAVEL ABROAD
海外旅行 記事一覧

インドのバンガロールに出張した時、タクシーで牛と併走しましたスペインのラマンチャで見る風車がデカかったアメリカからバスでカナダのナイアガラの滝で虹が見れて感動しました!深夜のNYタイムズスクエア香港の夜景は船からアメリカのレンタカー代でいくら?グランドキャニオンまでドライブ

JOBS
お仕事 記事一覧

外資系企業に転職するエンジニアの苦悩TOEICの点数 重要だよね外資系企業 面接対等
上へ

CATEGORY
カテゴリ

PROFILE
プロフィール

これくらいブログKoReKuRaiです。神奈川県在住。外資系IT業界でお仕事続けて12年。現在、3歳児の子育てに奮闘中です。ビジネス英会話、転職、出張、旅行記や子育て、サイト作成やコーディングに色々役立つと思うブログを書き足していきます。拙い文章ですがよろしくお願いします。メールはこちらまでお願いします。

Copyright 2017 KoReKuRai All Rights Reserved.