質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

4回答

5298閲覧

[MySQL]2つのテーブルにある同じカラム名のデータを一緒にUPDATEする方法

newyee

総合スコア213

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2017/09/23 16:17

編集2017/09/23 16:18

MysqlのUPDATE文に関してご質問があります。
仮に、テーブル「drink_info_table」と「drink_stock_table」に同じ名前のカラム「update_at」があったとしまして、
この、「update_at」をupdate文で同時に書き換えることはできるでしょうか?
一つ一つ、sql書いて~実行して、というのは少し要領悪い気がしたもので...
教えて下さる方いましたら、ご教授ください!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

SVC34

2017/09/24 03:52 編集

update_atはdate型もしくはtimestamp型でしょうか。date型やtimestamp型の場合、その値はどこから取得するつもりでしょうか。同時に更新する2つのテーブルのupdate_atは完全に一致させる必要がありますか。
newyee

2017/09/24 08:50

ご返信ありがとうございます。update_atはdatetime型になります。update_atはdrink_info_tableとdrink_stock_tableの更新情報でして、同時に更新されないと、データに不整合が発生すると思ったため、一緒のupdate文に含める必要があると思いました。
guest

回答4

0

「drink_info_table」と「drink_stock_table」に同じ名前のカラム「update_at」

常におなじupdate_atとなるのであれば
どちらかに寄せてしまえばいいでしょう。
「drink_info_table」と「drink_stock_table」にレコードの同一性を担保するidを振り
仮に「drink_info_table」を主とするなら「drink_stock_table」は「update_at」を
もたず、必要があればidを元に「drink_info_table」に見に行けばいいでしょう。

投稿2017/09/25 03:11

yambejp

総合スコア114784

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

newyee

2017/09/25 12:59

ご返信ありがとうございます。 説明不足で申し訳ないのですが、2つのテーブルには「drink_id」というカラムを設定していまして、これにはPRIMARYキーを設定し、A_I属性を付加しています。 この「drink_id」についてなのですが、yambe.jpさんがご説明下さった「レコードの同一性を担保するid」ということになりますでしょうか? つまり「update_at」は2つのテーブルには必要ではなく、「drink_info_table」にのみ設定しておき、更新情報をみたい場合は、「drink_id」を元に「drink_info_table」をチェックする、という理解で合っていますでしょうか?
guest

0

ひとつのテーブルのみでUPDATE文はこうなっています。

sql

1UPDATE [LOW_PRIORITY] [IGNORE] table_reference 2 SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ... 3 [WHERE where_condition] 4 [ORDER BY ...] 5 [LIMIT row_count]

複数のテーブルを UPDATEしたい場合は以下のようになります。

sql

1UPDATE [LOW_PRIORITY] [IGNORE] table_references 2 SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ... 3 [WHERE where_condition]

単一テーブル構文の場合、UPDATE ステートメントは、指定されたテーブル内の既存の行のカラムを新しい値に更新します。SET 句は、変更するカラムと、それらのカラムに指定される値を示します。各値は式か、またはカラムを明示的にそのデフォルト値に設定するキーワード DEFAULT として指定できます。WHERE 句 (指定されている場合) は、どの行を更新するかを識別する条件を指定します。WHERE 句がない場合は、すべての行が更新されます。ORDER BY 句が指定されている場合は、指定されている順序で行が更新されます。LIMIT 句は、更新できる行数に制限を設定します。

複数テーブル構文の場合、UPDATE は、条件を満たす table_references で指定されている各テーブル内の行を更新します。一致した各行は、条件に複数回一致した場合でも、1 回更新されます。複数テーブル構文の場合は、ORDER BY および LIMIT を使用できません。

パーティション化されたテーブルの場合は、このステートメントの単一テーブルと複数テーブルの両方の形式で、テーブル参照の一部としての PARTITION オプションの使用がサポートされます。このオプションは、1 つ以上のパーティションまたはサブパーティション (またはその両方) のリストを受け取ります。リストされているパーティション (またはサブパーティション) だけが一致をチェックされ、これらのパーティションまたはサブパーティションのいずれにも存在しない行は、where_condition を満たすかどうかにかかわらず更新されません。

投稿2017/09/24 02:49

naohiro19_

総合スコア178

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

updateによる複数テーブルの同時更新は、リファレンスに複数テーブル構文として明記(バージョン5.Xであれば)されています。

ただ、「update_at」のみの更新を複数テーブルに対して、というのであれば、「update_at」の本来の目的には沿ぐわないので、お薦めしません。

update文に含めるのが冗長というのであれば、updateトリガーによって行う方法もあります。

投稿2017/09/24 01:53

編集2017/09/24 01:56
sazi

総合スコア25173

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

教えて!gooの「SQL 複数テーブルのupdate」の記事が参考になるでしょう。
実質は2回updateを発行するようなprocedureを組むことです。

投稿2017/09/23 16:34

編集2017/09/23 16:36
seastar3

総合スコア2285

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問