MySQL數(shù)據(jù)庫(kù)TIMESTAMP設(shè)置默認(rèn)值的靈活運(yùn)用,本次我們接著上次的內(nèi)容介紹幾個(gè)MySQL數(shù)據(jù)庫(kù)TIMESTAMP設(shè)置默認(rèn)值的幾個(gè)應(yīng)用實(shí)例,希望能夠?qū)δ兴鶐椭?/p>
創(chuàng)新互聯(lián)主營(yíng)長(zhǎng)子網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP軟件開(kāi)發(fā),長(zhǎng)子h5重慶小程序開(kāi)發(fā)公司搭建,長(zhǎng)子網(wǎng)站營(yíng)銷推廣歡迎長(zhǎng)子等地區(qū)企業(yè)咨詢
#1查看表定義,可以看到b列有個(gè)屬性O(shè)N UPDATE CURRENT_TIMESTAMP,導(dǎo)致更新數(shù)據(jù)時(shí),即便未涉及到該列,該列數(shù)據(jù)也被自動(dòng)更新。另一方面,c列默認(rèn)值是'0000-00-00 00:00:00',實(shí)際插入已經(jīng)被自動(dòng)賦值為current_timestamp。
?echo("當(dāng)前時(shí)間為:".date("Y-m-d h:i:s")."br");$n=strtotime(date("Y-m-d h:i:s"));//用PHP時(shí)間戳轉(zhuǎn)化為數(shù)字 echo("用PHP時(shí)間戳轉(zhuǎn)化為數(shù)字:".$n)."br";$n=date("Y-m-d h:i:s",$n);//顯示的時(shí)候再轉(zhuǎn)化為時(shí)間:echo("顯示的時(shí)候再轉(zhuǎn)化為時(shí)間:".$n)."br";?
1. MySQL 獲得當(dāng)前時(shí)間戳函數(shù):current_timestamp, current_timestamp()
mysql select current_timestamp, current_timestamp();
+---------------------+---------------------+
| current_timestamp | current_timestamp() |
+---------------------+---------------------+
| 2008-08-09 23:22:24 | 2008-08-09 23:22:24 |
+---------------------+---------------------+
2. MySQL (Unix 時(shí)間戳、日期)轉(zhuǎn)換函數(shù):
unix_timestamp(),
unix_timestamp(date),
from_unixtime(unix_timestamp),
from_unixtime(unix_timestamp,format)
下面是示例:
select unix_timestamp(); -- 1218290027
select unix_timestamp('2008-08-08'); -- 1218124800
select unix_timestamp('2008-08-08 12:30:00'); -- 1218169800
select from_unixtime(1218290027); -- '2008-08-09 21:53:47'
select from_unixtime(1218124800); -- '2008-08-08 00:00:00'
select from_unixtime(1218169800); -- '2008-08-08 12:30:00'
select from_unixtime(1218169800, '%Y %D %M %h:%i:%s %x'); -- '2008 8th August 12:30:00 2008'
3. MySQL 時(shí)間戳(timestamp)轉(zhuǎn)換、增、減函數(shù):
timestamp(date) -- date to timestamp
timestamp(dt,time) -- dt + time
timestampadd(unit,interval,datetime_expr) --
timestampdiff(unit,datetime_expr1,datetime_expr2) --
請(qǐng)看示例部分:
可以了解一下MySQL的時(shí)間戳(Timestamp)數(shù)據(jù)類型:
默認(rèn)時(shí)間戳(Timestamp)類型的取值范圍為'1970-01-01 00:00:01' UTC至'2038-01-19 03:14:07' UTC,數(shù)據(jù)精確到秒級(jí)別,該取值范圍包含約22億個(gè)數(shù)值,因此在MySQL內(nèi)部使用4個(gè)字節(jié)INT類型來(lái)存放時(shí)間戳數(shù)據(jù):
1、在存儲(chǔ)時(shí)間戳數(shù)據(jù)時(shí),先將本地時(shí)區(qū)時(shí)間轉(zhuǎn)換為UTC時(shí)區(qū)時(shí)間,再將UTC時(shí)區(qū)時(shí)間轉(zhuǎn)換為INT格式的毫秒值(使用UNIX_TIMESTAMP函數(shù)),然后存放到數(shù)據(jù)庫(kù)中。
2、在讀取時(shí)間戳數(shù)據(jù)時(shí),先將INT格式的毫秒值轉(zhuǎn)換為UTC時(shí)區(qū)時(shí)間(使用FROM_UNIXTIME函數(shù)),然后再轉(zhuǎn)換為本地時(shí)區(qū)時(shí)間,最后返回給客戶端。
(Timestamp)時(shí)間戳列可以有四張組合定義,其含義分別為:
1、當(dāng)字段定義為timestamp,表示該字段在插入和更新時(shí)都不會(huì)自動(dòng)設(shè)置為當(dāng)前時(shí)間。
2、當(dāng)字段定義為timestamp DEFAULT CURRENT_TIMESTAMP,表示該字段僅在插入且未指定值時(shí)被賦予當(dāng)前時(shí)間,再更新時(shí)且未指定值時(shí)不做修改。
3、當(dāng)字段定義為timestamp ON UPDATE CURRENT_TIMESTAMP,表示該字段在插入且未指定值時(shí)被賦值為"0000-00-00 00:00:00",在更新且未指定值時(shí)更新為當(dāng)前時(shí)間。
4、當(dāng)字段定義為timestamp DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,表示該字段在插入或更新時(shí)未指定值,則被賦值為當(dāng)前時(shí)間。
通常存儲(chǔ)時(shí)間用datetime類型,現(xiàn)在很多系統(tǒng)也用int存儲(chǔ)時(shí)間,它們有什么區(qū)別?個(gè)人更喜歡使用int這樣對(duì)于日期計(jì)算時(shí)比較好哦,下面我們一起來(lái)看到底那種會(huì)好些。
int
(1).4個(gè)字節(jié)存儲(chǔ),INT的長(zhǎng)度是4個(gè)字節(jié),存儲(chǔ)空間上比datatime少,int索引存儲(chǔ)空間也相對(duì)較小,排序和查詢效率相對(duì)較高一點(diǎn)點(diǎn)
(2)可讀性極差,無(wú)法直觀的看到數(shù)據(jù),可能讓你很惱火
TIMESTAMP
(1)4個(gè)字節(jié)儲(chǔ)存
(2)值以UTC格式保存
(3)時(shí)區(qū)轉(zhuǎn)化 ,存儲(chǔ)時(shí)對(duì)當(dāng)前的時(shí)區(qū)進(jìn)行轉(zhuǎn)換,檢索時(shí)再轉(zhuǎn)換回當(dāng)前的時(shí)區(qū)。
(4)TIMESTAMP值不能早于1970或晚于2037