ホームページ >php教程 >php手册 >PHP と MySQL のタイムゾーンの概要

PHP と MySQL のタイムゾーンの概要

WBOY
WBOYオリジナル
2016-06-13 12:30:32987ブラウズ

PHP スクリプト側の都市設定は、php.ini で date.timezone キーの値を「Asia/Shanghai」に設定できます。ただし、通常、共有仮想ホスト自体には php.ini を変更する権限がありません。このとき、php.ini の設定を動的に変更するには、プログラムの public 部分に

ini_set('date.timezone','Asia/Shanghai'); を追加する必要があります。次に、時間が正しいかどうかをテストできます。

var_dump(date()); サーバーの現地時間が正しい場合、問題は通常解決されます。添付のとおり、PHP 5.1 以降では、対応するタイム ゾーンを変更するための特別な関数が提供されています:

date_default_timezone_set('Asia/Shanghai'); この関数の方が汎用性が高いため、使用することをお勧めします。 「アジア/上海」に対応して使用できる他の本土のタイムゾーンは次のとおりです。アジア/重慶、アジア/上海、アジア/ウルムチ (順に、重慶、上海、ウルムチ)。香港と台湾では、アジア/マカオ、アジア/香港、アジア/台北 (マカオ、香港、台北の順)、およびシンガポール: 他の利用可能な値は次のとおりです: Etc/GMT-8、シンガポール、香港、中国。 。

しかし、PHP 側でタイムゾーンを変更することに成功した後、日付が正しく記録されていないことがわかりました。このとき、データベースの問題ではないかと考えました。当然のことながら、プログラムによって挿入された関数は PHP の時刻を呼び出すのではなく、MySQL の CURRECT_TIMESTAMP を直接使用するためです。このとき、MySQL のタイムゾーンを変更できるかどうかを検討する必要があります。

MySQL ドキュメントを参照し、実行可能な SQL ステートメントを見つけました:

SET GLOBAL time_zone = ' 8:00'; ここで、 ' 8:00' は East Eighth District、Other Urban を表します。地域もそれに続く。そして、このステートメントをデータベース モデルに挿入すると、権限が不十分であることがわかりました (仮想ホスト プロバイダー)。次に、次のような多くのステートメントをデバッグしました:

DATE_ADD(UTC_TIMESTAMP(), INTERVAL 8 HOUR); タイムゾーンを表示する SQL ステートメント:

SHOW VARIABLES LIKE 'system_time_zone' など。 MySQL の権限制限により、完全な解決策はありません。グーグルで調べたところ、外国人が非常に良い解決策を持っていることがわかりました。ただし、データを挿入する各 SQL ステートメントを変更する必要があります。この解決策はあまり効果的ではありません。データベースのタイムゾーンを通常に変更した後は、対応する SQL ステートメントを元に戻す必要があります。

そして、PHP 側はすでに時間の問題を正しく解決できるため、それが考えられます。 MySQL データベースは対応する関数を使用して解決できますが、将来別のホスト環境に移行する場合は元に戻す必要があります。対応するフィールドは TIMESTAMP 型で、デフォルト値は CURRECT_TIMESTAMP です。もちろん、時間を指定することもできます。

次に、私のアプローチは、PHP に現在の正しい時刻を挿入させることです。ただし、それに応じてプログラムを変更する必要があります。ただし、将来構成を変更する場合は、1 か所を変更するだけで済みます。最終的にデータベースに挿入するときは、次の形式に注意してください:

date('Y-m-d H:i:s') これで問題は解決します。非常に優れた参考資料をいくつか添付しました:

http://www.modwest.com/help/kb6-256.html
http://topic.csdn.net/t/20060503/07 / 4728521.html
http://www.phpchina.com/5173/viewspace_5132.html
http://www.phpx.com/pth110355.php
更新: このことから、wiLdGoose 兄弟は次のように述べています。同じ問題が発生しましたが、解決できませんでした。その結果、さまざまな推測と判断を経て、最終的には Zend Studio のタイムゾーン設定の問題であることがわかりました(汗)。動作環境だけでなく、開発環境も以下の点に注意する必要があるようです。
私も今日この問題に遭遇しました。私はあなたよりも幸運です。
SET GLOBAL time_zone = ' 8:00';
ははは、残念ですね。 UNIX_TIMESTAMP() のような関数は使用しないでください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。