乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      有關(guān) PHP 和 MySQL 時(shí)區(qū)的一點(diǎn)總結(jié)

       xf_baby 2014-01-10
      PHP 腳本端的市區(qū)設(shè)置可以在 php.ini 下設(shè)置 date.timezone 鍵的值為 'Asia/Shanghai' 即可。
      但是通常共享虛擬主機(jī)本身沒有修改 php.ini 權(quán)限。這個(gè)時(shí)候就應(yīng)該在程序公共部分加入:
      ini_set('date.timezone','Asia/Shanghai');動(dòng)態(tài)修改 php.ini 的設(shè)置。之后可以測(cè)試一下時(shí)間是否正確: 

      var_dump(date());如果服務(wù)器的本地時(shí)間是正確的,那么一般就能解決問題了。附,PHP 5.1 以上提供了專門的函數(shù)修改對(duì)應(yīng)的時(shí)區(qū): 

      date_default_timezone_set('Asia/Shanghai');建議使用此函數(shù),因?yàn)楦ㄓ靡恍?duì)應(yīng) 'Asia/Shanghai' 其他可以使用的大陸時(shí)區(qū)還有:Asia/Chongqing 、Asia/Shanghai 、Asia/Urumqi (依次為重慶,上海,烏魯木齊);港臺(tái)地區(qū)可用:Asia/Macao、Asia/Hong_Kong、Asia/Taipei(依次為澳門,香港,臺(tái)北);還有新加坡:Asia/Singapore;其他可用的值是:Etc/GMT-8、Singapore、Hongkong、PRC;老外好像把北京漏調(diào)了。 

      但是,在我修改成功 PHP 端的時(shí)區(qū)以后發(fā)現(xiàn)日期并沒有正確的記錄下來。這個(gè)時(shí)候我考慮是否是數(shù)據(jù)庫(kù)的問題。果不其然,因?yàn)槌绦虿迦氲暮瘮?shù)并沒有調(diào)用 PHP 的時(shí)間,而是直接使用 MySQL 的 CURRECT_TIMESTAMP。這個(gè)時(shí)候就要考慮是否能修改 MySQL 方面的時(shí)區(qū)。 

      參考了 MySQL 的文檔,發(fā)現(xiàn)一個(gè)可行的 SQL 語(yǔ)句為: 

      SET GLOBAL time_zone = '+8:00'; 其中 '+8:00' 是東八區(qū)的表示方法,其他的市區(qū)依次類推。而我在數(shù)據(jù)庫(kù)模型中插入改語(yǔ)句發(fā)現(xiàn)權(quán)限不夠(該死的虛擬主機(jī)提供商)。接下來我調(diào)試了很多語(yǔ)句,比如:

      DATE_ADD(UTC_TIMESTAMP(), INTERVAL 8 HOUR);顯示時(shí)區(qū)的 SQL 語(yǔ)句: 

      SHOW VARIABLES LIKE 'system_time_zone'等等。而由于 MySQL 權(quán)限的限制并沒有徹底的解決方案。我 Google 了下,發(fā)現(xiàn)老外這個(gè)有一個(gè)非常好的解決方案。但是他需要修改每條插入數(shù)據(jù)的 SQL 語(yǔ)句。這樣的方案并不是非常的有效,一旦數(shù)據(jù)庫(kù)時(shí)區(qū)改成正常,那么相應(yīng)的 SQL 語(yǔ)句又要改回來。 

      而我考慮既然 PHP 端已經(jīng)可以正確的解決時(shí)間的問題了。MySQL 數(shù)據(jù)庫(kù)方面雖然可以使用相應(yīng)的函數(shù)解決,但是如果日后遷移到別的主機(jī)環(huán)境又要改回來。而相應(yīng)的字段是一個(gè) TIMESTAMP 類型的,默認(rèn)的值為 CURRECT_TIMESTAMP,當(dāng)然是可以指定時(shí)間的。 

      那么我的做法就是讓 PHP 插入當(dāng)前正確的時(shí)間,這樣雖然程序方面需要做相應(yīng)的修改。不過日后配置修改起來只要修改一處就可以了。最后插入數(shù)據(jù)庫(kù)的時(shí)間注意一下格式: 
      date('Y-m-d H:i:s')這樣就可以解決問題了。

      更新:由此 wiLdGoose 兄說他也碰到同樣的問題,但是無法解決。結(jié)果經(jīng)過種種的假設(shè)和判斷以后,到最后發(fā)現(xiàn)原來是 Zend Studio 的時(shí)區(qū)配置問題(我狂汗ing)??磥沓ミ\(yùn)行環(huán)境,開發(fā)環(huán)境也是需要注意以下的。 
      今天我也遇到這個(gè)問題了,我比你幸運(yùn),自己的主機(jī),可以: 
      SET GLOBAL time_zone = '+8:00';  
      呵呵,你可惜了,不能用 UNIX_TIMESTAMP() 這樣的函數(shù)了.

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多