日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 20小时内,mysql中关于date(Y-m-d H:i:s) 入库慢8小时的解决

發布時間:2023/12/15 数据库 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 20小时内,mysql中关于date(Y-m-d H:i:s) 入库慢8小时的解决 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原來從php5.1.0開始,php.ini里加入了date.timezone這個選項,默認情況下是關閉的。每次在插入庫時,發現這個registration_date datetime 總是慢了8小時。我試著修改php.ini但一直沒有成功。后來修正代碼實現了。我這是iis6平臺,可能與這個有關系。

經測試:

$timeoffset = 8;

echo gmdate("Y-m-d H:i:s", mktime() + $timeoffset * 3600) . "
";

echo gmdate("Y-m-d H:i:s", time() + $timeoffset * 3600) . "
";

echo date("Y-m-d H:i:s", mktime() + $timeoffset * 3600) . "
";

echo date("Y-m-d H:i:s", time() + $timeoffset * 3600) . "
";

都輸出:

2007-11-24 17:41:58

2007-11-24 17:41:58

2007-11-24 17:41:58

2007-11-24 17:41:58

可見,以上幾種寫法都是正確的,但會有什么區別了,我又研究了一下。區別如下:

date()和gmdate(),在官方的文檔中的描述為:

date -- 格式化一個本地時間/日期

gmdate -- 格式化一個 GMT/UTC 日期/時間,返回的是格林威治標準時(GMT)。

可是,我上面輸出結果相同,是因為是在win平臺下測試的,如果是在Linux+Apache下運行PHP所得的結果會差8小時的。

所以,我們應該給一個兼容性的寫法,統一使用gmdate,并手工設置當前時區,寫法改進如下:

echo gmdate('Y-m-d H:i:s', time() + 3600 * 8);

這樣不管在Linux+Apache下還是Windows下都得到了正確的結果,當然這樣寫還有一個好處,當網站是面向全世界的時候,那么網站用戶只要設置所在的時區,程序自動根據用戶設置的時區進行時間計算,數據庫中信息發布時間只存當前的time()所生成的時間,那么在中國+8時區看到的發布時間是:2007-03-14 12:15:27,那么在歐洲+2時區用戶看到這個信息的發布時間是:2007-11-24 17:41:58,這樣信息的時間就全部對應正確了。

另外,int time ( void )返回自從 Unix 紀元(格林威治時間 1970 年 1 月 1 日 00:00:00)到當前時間的秒數。

mktime -- 取得一個日期的 Unix 時間戳,根據給出的參數返回 Unix 時間戳。時間戳是一個長整數,包含了從 Unix 紀元(January 1 1970 00:00:00 GMT)到給定時間的秒數。

int mktime ( [int hour [, int minute [, int second [, int month [, int day [, int year [, int is_dst]]]]]]] )

參數

hour

小時數。

minute

分鐘數。

second

秒數(一分鐘之內)。

month

月份數。

day

天數。

year

年份數,可以是兩位或四位數字,0-69 對應于 2000-2069,70-100 對應于 1970-2000。在如今系統中普遍把 time_t 作為一個 32 位有符號整數的情況下,year 的合法范圍是 1901 到 2038 之間,不過此限制自 PHP 5.1.0 起已被克服了。

is_dst

本參數可以設為 1,表示正處于夏時制時間(DST),0 表示不是夏時制,或者 -1(默認值)表示不知道是否是夏時制。如果未知,PHP 會嘗試自己搞明白。這可能產生不可預知(但并非不正確)的結果。如果 PHP 運行的系統中啟用了 DST 或者 is_dst 設為 1,某些時間是無效的。例如 DST 自 2:00 生效,則所有處于 2:00 到 3:00 之間的時間都無效,mktime() 會返回一個未定義(通常為負)的值。某些系統(例如 Solaris 8)的 DST 在午夜生效,則 DST 生效當天的 0:30 會被計算為前一天的 23:30

string date ( string format [, int timestamp] )

返回將整數 timestamp 按照給定的格式字串而產生的字符串。如果沒有給出時間戳則使用本地當前時間。換句話說,timestamp 是可選的,默認值為 time()。

解決系統時間慢8小時完美版「2008-9-26 補充by zhoz」:

ini_set("date.timezone", 'Asia/Shanghai'); // 系統時區

將以上這句放入系統文件中,保證其它文件都能讀取,以校正時區。

修改linux的時間可以使用date指令「2008-12-1 補充by zhoz」:

在命令行輸入:

date

顯示當前時間 11月 27日 10:03:16 CST 2008

date -s

按字符串方式修改時間

可以只修改日期,不修改時間,輸入: date -s 2008-11-27

只修改時間,輸入:date -s 10:03:00

同時修改日期時間,注意要加雙引號,日期與時間之間有一空格,輸入:date -s "2008-11-27 10:03:00"

修改完后,記得輸入:clock -w

把系統時間寫入CMOS

總結

以上是生活随笔為你收集整理的mysql 20小时内,mysql中关于date(Y-m-d H:i:s) 入库慢8小时的解决的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。