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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

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

原來從php5.1.0開始,php.ini里加入了date.timezone這個(gè)選項(xiàng),默認(rèn)情況下是關(guān)閉的。每次在插入庫時(shí),發(fā)現(xiàn)這個(gè)registration_date datetime 總是慢了8小時(shí)。我試著修改php.ini但一直沒有成功。后來修正代碼實(shí)現(xiàn)了。我這是iis6平臺,可能與這個(gè)有關(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 -- 格式化一個(gè)本地時(shí)間/日期

gmdate -- 格式化一個(gè) GMT/UTC 日期/時(shí)間,返回的是格林威治標(biāo)準(zhǔn)時(shí)(GMT)。

可是,我上面輸出結(jié)果相同,是因?yàn)槭窃趙in平臺下測試的,如果是在Linux+Apache下運(yùn)行PHP所得的結(jié)果會差8小時(shí)的。

所以,我們應(yīng)該給一個(gè)兼容性的寫法,統(tǒng)一使用gmdate,并手工設(shè)置當(dāng)前時(shí)區(qū),寫法改進(jìn)如下:

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

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

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

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

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

參數(shù)

hour

小時(shí)數(shù)。

minute

分鐘數(shù)。

second

秒數(shù)(一分鐘之內(nèi))。

month

月份數(shù)。

day

天數(shù)。

year

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

is_dst

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

string date ( string format [, int timestamp] )

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

解決系統(tǒng)時(shí)間慢8小時(shí)完美版「2008-9-26 補(bǔ)充by zhoz」:

ini_set("date.timezone", 'Asia/Shanghai'); // 系統(tǒng)時(shí)區(qū)

將以上這句放入系統(tǒng)文件中,保證其它文件都能讀取,以校正時(shí)區(qū)。

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

在命令行輸入:

date

顯示當(dāng)前時(shí)間 11月 27日 10:03:16 CST 2008

date -s

按字符串方式修改時(shí)間

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

只修改時(shí)間,輸入:date -s 10:03:00

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

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

把系統(tǒng)時(shí)間寫入CMOS

總結(jié)

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

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。