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小时的解决的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何在php中写内容,请问如何在内容模板
- 下一篇: oracle sql序列,SQL ser