mysql 20小时内,mysql中关于date(Y-m-d H:i:s) 入库慢8小时的解决
原來從php5.1.0開始,php.ini里加入了date.timezone這個選項,默認情況下是關(guān)閉的。每次在插入庫時,發(fā)現(xiàn)這個registration_date datetime 總是慢了8小時。我試著修改php.ini但一直沒有成功。后來修正代碼實現(xiàn)了。我這是iis6平臺,可能與這個有關(guān)系。
經(jīng)測試:
$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
可見,以上幾種寫法都是正確的,但會有什么區(qū)別了,我又研究了一下。區(qū)別如下:
date()和gmdate(),在官方的文檔中的描述為:
date -- 格式化一個本地時間/日期
gmdate -- 格式化一個 GMT/UTC 日期/時間,返回的是格林威治標準時(GMT)。
可是,我上面輸出結(jié)果相同,是因為是在win平臺下測試的,如果是在Linux+Apache下運行PHP所得的結(jié)果會差8小時的。
所以,我們應該給一個兼容性的寫法,統(tǒng)一使用gmdate,并手工設(shè)置當前時區(qū),寫法改進如下:
echo gmdate('Y-m-d H:i:s', time() + 3600 * 8);
這樣不管在Linux+Apache下還是Windows下都得到了正確的結(jié)果,當然這樣寫還有一個好處,當網(wǎng)站是面向全世界的時候,那么網(wǎng)站用戶只要設(shè)置所在的時區(qū),程序自動根據(jù)用戶設(shè)置的時區(qū)進行時間計算,數(shù)據(jù)庫中信息發(fā)布時間只存當前的time()所生成的時間,那么在中國+8時區(qū)看到的發(fā)布時間是:2007-03-14 12:15:27,那么在歐洲+2時區(qū)用戶看到這個信息的發(fā)布時間是:2007-11-24 17:41:58,這樣信息的時間就全部對應正確了。
另外,int time ( void )返回自從 Unix 紀元(格林威治時間 1970 年 1 月 1 日 00:00:00)到當前時間的秒數(shù)。
mktime -- 取得一個日期的 Unix 時間戳,根據(jù)給出的參數(shù)返回 Unix 時間戳。時間戳是一個長整數(shù),包含了從 Unix 紀元(January 1 1970 00:00:00 GMT)到給定時間的秒數(shù)。
int mktime ( [int hour [, int minute [, int second [, int month [, int day [, int year [, int is_dst]]]]]]] )
參數(shù)
hour
小時數(shù)。
minute
分鐘數(shù)。
second
秒數(shù)(一分鐘之內(nèi))。
month
月份數(shù)。
day
天數(shù)。
year
年份數(shù),可以是兩位或四位數(shù)字,0-69 對應于 2000-2069,70-100 對應于 1970-2000。在如今系統(tǒng)中普遍把 time_t 作為一個 32 位有符號整數(shù)的情況下,year 的合法范圍是 1901 到 2038 之間,不過此限制自 PHP 5.1.0 起已被克服了。
is_dst
本參數(shù)可以設(shè)為 1,表示正處于夏時制時間(DST),0 表示不是夏時制,或者 -1(默認值)表示不知道是否是夏時制。如果未知,PHP 會嘗試自己搞明白。這可能產(chǎn)生不可預知(但并非不正確)的結(jié)果。如果 PHP 運行的系統(tǒng)中啟用了 DST 或者 is_dst 設(shè)為 1,某些時間是無效的。例如 DST 自 2:00 生效,則所有處于 2:00 到 3:00 之間的時間都無效,mktime() 會返回一個未定義(通常為負)的值。某些系統(tǒng)(例如 Solaris 8)的 DST 在午夜生效,則 DST 生效當天的 0:30 會被計算為前一天的 23:30
string date ( string format [, int timestamp] )
返回將整數(shù) timestamp 按照給定的格式字串而產(chǎn)生的字符串。如果沒有給出時間戳則使用本地當前時間。換句話說,timestamp 是可選的,默認值為 time()。
解決系統(tǒng)時間慢8小時完美版「2008-9-26 補充by zhoz」:
ini_set("date.timezone", 'Asia/Shanghai'); // 系統(tǒng)時區(qū)
將以上這句放入系統(tǒng)文件中,保證其它文件都能讀取,以校正時區(qū)。
修改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
把系統(tǒng)時間寫入CMOS
總結(jié)
以上是生活随笔為你收集整理的mysql 20小时内,mysql中关于date(Y-m-d H:i:s) 入库慢8小时的解决的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何在php中写内容,请问如何在内容模板
- 下一篇: php高效下载文件,LinkCache