所以存到數據庫也有兩種形式了(真正不止,我的應用就兩種),時間戳類型我是保存為字符串的,這個是比較方便的.
正常日期類型是保存為DATE型的.
這兩個PHP時間要注意一下,我平時用兩種,所以,前幾天建的表,把時間類型存為DATE的,我還一直用時間戳保存,一直資料寫不進表,調試了好久的才知錯誤之處,是類型不符合,不給寫入庫.
像上面的時間戳是比較方便,但,顯示的時候,不至於把這個1228348800串給客戶看吧,GOD NOWS!
所 以就用到了這兩個的轉換,先說一下如何取得當前的時間戳,$date1=time();這樣就取得當前的時間戳了,要轉回2008-12-4這種格式呢, 用到date()這個函數了,在PHP中date()函數比較常用,如取得當前日期,可以用$date2=date('Y-m-d');,關於裡面參數的 意思,如不懂就查一下php的手冊了.
好,言歸正傳,把1228348800轉成2008-12-4格式代碼如下:
$date3=date('Y-m-d H:i:s',"1228348800");
這樣就OK了,如還想得到小時,分鐘秒,只要把'Y-m-d'改一下就可以了,不過要注意一下,PHP時間好像有8個小時的誤差.加上就OK了.
時間戳轉正常日期有了,反之呢,把正常日期格式轉為時間戳呢,請看如下代碼:
$year=((int)substr("2008-12-04",0,4));//取得年份
$month=((int)substr("2008-12-04",5,2));//取得月份
$day=((int)substr("2008-12-04",8,2));//取得幾號
echo mktime(0,0,0,$month,$day,$year);
這樣就能把正常日期轉成時間戳了,這裡如果有時分秒也是同理,
注意:php5.1以上時間戳會與實際時間相差8小時,PHP時間的具體解決辦法如下
1、最簡單的方法就是不要用php5.1以上的版本--顯然這是不可取的方法!!!
2、修改php.ini。打開php.ini查找date.timezone 去掉前面的分號= 後面加Asia/Shanghai,重啟apache服務器即可--缺點就是如果程序放到別人的服務器上,不能修改php.ini,那就奈何不得了。
3、在程序中添加時間的初始化的語句的 即:“date_default_timezone_set("Asia/Shanghai"); ”這個可以由程序員任意設置,我的推薦。
時區標識符,大陸內地可用的PHP時間值是:PRC,Asia/Chongqing ,Asia/Shanghai ,Asia/Urumqi (依次為中國,重慶,上海,烏魯木齊) ,Etc/GMT-8,Asia/Harbin
港台地區可用:Asia/Macao ,Asia/Hong_Kong ,Asia/Taipei (依次為澳門,香港,台北)
還有新加坡:Asia/Singapore
澳大利亞:Australia/Sydney