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

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

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

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

SQL

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

Q&A

解決済

2回答

554閲覧

2つのテーブルを結合してアップデートを行いたい

n.yom

総合スコア3

MySQL

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

SQL

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

0グッド

1クリップ

投稿2020/08/12 00:01

編集2020/08/12 00:24

SQL初心者です。
データベースはmySQLです。
2つのテーブルを組み合わせ、掲載終了日(end_date)が来たとき、公開フラグ(koukai_flg)を0にするという更新を行いたいです。

UPDATE TABLE1
SET koukai_flg = 0
FROM TABLE1
INNER JOIN TABLE2
ON TABLE1.site_id = TABLE2.site_id
WHERE koukai_flg = 1
AND end_date < now()

2つのテーブルを結合してアップデート、を試してみたところうまくいかずに困っています。
どなたかお詳しい方、ご回答よろしくお願いします。

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

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

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

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

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

dodox86

2020/08/12 00:08

何のデータベースシステムを使用しているか明示しましょう。(MySQLとかOracleとかPostgreSQLとかMicrosoft SQL Serverとか)日時を扱う関数の仕様がそれぞれ違っていたりします。
n.yom

2020/08/12 00:14

失礼しました、heidiSQLです。
dodox86

2020/08/12 00:18

質問に関する追加情報はこのコメント欄ではなく、質問文への追記、修正で書きましょう。そうすることで質問内容がより明確になります。それと、heidiSQLとはどうもRDBMSそのものではなく、単なるGUIの管理ソフトのようです。そのソフトが接続しているDBそのものの種類(製品名)を明示してください。
sazi

2020/08/12 00:22 編集

heidiSQLは管理ツールです。使用しているDBMSの種類が必要です。
n.yom

2020/08/12 00:24

編集しました、ご指摘ありがとうございます。 また、最初の質問はnow()にしたところ、解決出来ましたので質問を変更させていただきました。
sazi

2020/08/12 00:28 編集

上手くいかないとは具体的に何ですか? エラーになる?エラーにはならないが更新されない?
n.yom

2020/08/12 00:28

エラーになってしまいます。
sazi

2020/08/12 00:28

koukai_flg やend_dateはどっちのテーブルの項目ですか? テーブルの定義も明示して下さい。
n.yom

2020/08/12 00:45

テーブルを定義したところ、解決出来ました。ありがとうございました。
dodox86

2020/08/12 00:47

成り行きに着いていけなかった。。。そもそもテーブルを定義(CREATE TABLE ...)してなかった、ということ?でしょうか。
sazi

2020/08/12 00:56

@dodox86さん せめてどのようなエラーなのかが分かればですけど、解決理由がさっぱりわかりませんよね。
n.yom

2020/08/12 00:59

where 以降の条件文(end_dateなど)に、どのテーブルのものかを定義したところ(TABLE1.end_dateなど)、解決することができました。 言葉足らずですみませんでした、次回以降からはどんなエラー文なのかも記入するように気を付けます。 ありがとうございます。
sazi

2020/08/12 01:05 編集

ベストアンサーの内容では解決しないので、自己解決にされた方が、後学者が誤解されずに済みます。 ※inner joinは取り入れられたのかもしれませんが。
n.yom

2020/08/12 01:12

記載しました。
guest

回答2

0

自己解決

この書き方で解決しました。

UPDATE TABLE1
INNER JOIN TABLE2
ON TABLE1.site_id = TABLE2.site_id
SET TABLE1.koukai_flg = 0
WHERE TABLE1.koukai_flg = 1
AND TABLE1.end_date < now()

投稿2020/08/12 01:11

編集2020/08/12 02:45
n.yom

総合スコア3

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

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

sazi

2020/08/12 01:22 編集

TABLE2は何のために結合しているのですか? inner joinなら絞り込みになるから分かるんですが、left joinで条件もないなら結合のコストが掛かるだけで意味が無いですけど。 単に条件の記述を省略しているだけでしょうか。
n.yom

2020/08/12 02:45 編集

すみません、INNERとLEFTを書き間違えていました。
guest

0

MySQLならこれで良かったと思いますが。

SQL

1UPDATE TABLE1 2INNER JOIN TABLE2 3ON TABLE1.site_id = TABLE2.site_id 4SET koukai_flg = 0 5WHERE koukai_flg = 1 6AND end_date < now()

投稿2020/08/12 00:30

yureighost

総合スコア2183

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

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

n.yom

2020/08/12 01:13

自己解決出来ました、ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問