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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

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

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

Q&A

1回答

1042閲覧

MySQLにINSERTすると時間が15時間ズレる

mizunana

総合スコア14

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

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

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

0グッド

0クリップ

投稿2018/09/06 07:57

編集2018/09/06 10:59

環境はAWSのRDSでMySQLを設定しています。
INSERTするのは、Nginx+Unicornで動くRuby on Railsです。

Viewデータから、投げた時間をInsertする時に時間が変更されます。
0時を入れると15時に、7時を入れると22時になります。

HTML

1<input class="timePick" name="starttime" placeholder="開始時間を入力してください">

受け取ったパラメータを下記のように格納します

Ruby

1@program.start_time = params[:starttime] 2~ 3@program.save

デバッグで、logger.debug(@program.start_time)をすると、07:00になっており、INSERT文の中だと22:00になります。
尚、ローカルであるvagrantの開発環境では問題なく動いております。

MySQLのタイムゾーンは東京に設定されており、Rails側のTimezoneも東京になっているのを確認しています。
考えられる原因がありましたら、ご教授の方よろしくお願い致します。

追記--------------------------
試したことを追記します。

パラメータで渡していたので、一度Rails側のControllerでTime.zone.parseしてみましたが、やはり無意味でした。

Ruby

1Time.zone.parse(params[:starttime])

直前までは07:00:00なのに、ログに記載されているINSERT文では22:00:00になっています。

追記2--------------------------
今まで何も気にしていなかったのですが、よく見ると
created_atとupdated_atもズレていることが分かり、それは9時間ほどズレていました。
なので、スタート時間のほうも9時間ズレていると思います。

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

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

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

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

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

x_x

2018/09/06 07:58

ずれは9時間ではないですか? 前日の分の
mizunana

2018/09/06 08:04

あ、なるほど。ありえますね……Time型なので時間しか見えないのですが、その可能性もあります。
guest

回答1

0

投稿2018/09/06 08:13

Orlofsky

総合スコア16415

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

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

mizunana

2018/09/06 09:10

ご回答ありがとうございます! ただ、その方法で試してみたのですが治りませんでした……。
Orlofsky

2018/09/06 09:14

ダメ元でMySQLを再起動してみてください。
mizunana

2018/09/06 10:07

再起動してみたのですが、駄目でしたね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問