欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > MySQL中datetime和timestamp的區別及使用詳解

MySQL中datetime和timestamp的區別及使用詳解

熱門標簽:常州網絡外呼系統開發 400電話申請信用卡 巫師三血與酒地圖標注 外呼系統電銷受騙 萊西市地圖標注 在哪里申請400電話 走過哪個省地圖標注 安徽ai電話電銷機器人有效果嗎 銷售語音電話機器人

一、MySQL中如何表示當前時間?

其實,表達方式還是蠻多的,匯總如下:

CURRENT_TIMESTAMP

CURRENT_TIMESTAMP()

NOW()

LOCALTIME

LOCALTIME()

LOCALTIMESTAMP

LOCALTIMESTAMP()

二、關于TIMESTAMP和DATETIME的比較

一個完整的日期格式如下:YYYY-MM-DD HH:MM:SS[.fraction],它可分為兩部分:date部分和time部分,其中,date部分對應格式中的“YYYY-MM-DD”,time部分對應格式中的“HH:MM:SS[.fraction]”。對于date字段來說,它只支持date部分,如果插入了time部分的內容,它會丟棄掉該部分的內容,并提示一個warning。

如下所示:

mysql> create table test(id int,hiredate date);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into test values(1,'20151208000000');
Query OK, 1 row affected (0.00 sec)

mysql> insert into test values(1,'20151208104400');
Query OK, 1 row affected, 1 warning (0.01 sec)

mysql> show warning;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'warning' at line 1
mysql> select * from test;
+------+------------+
| id  | hiredate  |
+------+------------+
|  1 | 2015-12-08 |
|  1 | 2015-12-08 |
+------+------------+
2 rows in set (0.00 sec)

注:第一個沒提示warning的原因在于它的time部分都是0

TIMESTAMP和DATETIME的相同點:

1> 兩者都可用來表示YYYY-MM-DD HH:MM:SS[.fraction]類型的日期。

 TIMESTAMP和DATETIME的不同點:

1> 兩者的存儲方式不一樣

對于TIMESTAMP,它把客戶端插入的時間從當前時區轉化為UTC(世界標準時間)進行存儲。查詢時,將其又轉化為客戶端當前時區進行返回。

而對于DATETIME,不做任何改變,基本上是原樣輸入和輸出。

下面,我們來驗證一下

首先創建兩種測試表,一個使用timestamp格式,一個使用datetime格式。

mysql> create table test(id int,hiredate timestamp);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into test values(1,'20151208000000');
Query OK, 1 row affected (0.00 sec)

mysql> create table test1(id int,hiredate datetime);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into test1 values(1,'20151208000000');
Query OK, 1 row affected (0.00 sec)

mysql> select * from test;
+------+---------------------+
| id  | hiredate      |
+------+---------------------+
|  1 | 2015-12-08 00:00:00 |
+------+---------------------+
1 row in set (0.01 sec)

mysql> select * from test1;
+------+---------------------+
| id  | hiredate      |
+------+---------------------+
|  1 | 2015-12-08 00:00:00 |
+------+---------------------+
1 row in set (0.00 sec)

兩者輸出是一樣的。

其次修改當前會話的時區

mysql> show variables like '%time_zone%'; 
+------------------+--------+
| Variable_name  | Value |
+------------------+--------+
| system_time_zone | CST  |
| time_zone    | SYSTEM |
+------------------+--------+
2 rows in set (0.00 sec)

mysql> set time_zone='+0:00';
Query OK, 0 rows affected (0.00 sec)

mysql> select * from test;
+------+---------------------+
| id  | hiredate      |
+------+---------------------+
|  1 | 2015-12-07 16:00:00 |
+------+---------------------+
1 row in set (0.00 sec)

mysql> select * from test1;
+------+---------------------+
| id  | hiredate      |
+------+---------------------+
|  1 | 2015-12-08 00:00:00 |
+------+---------------------+
1 row in set (0.01 sec)

上述“CST”指的是MySQL所在主機的系統時間,是中國標準時間的縮寫,China Standard Time UT+8:00

通過結果可以看出,test中返回的時間提前了8個小時,而test1中時間則不變。這充分驗證了兩者的區別。

2> 兩者所能存儲的時間范圍不一樣

timestamp所能存儲的時間范圍為:'1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999'。

datetime所能存儲的時間范圍為:'1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999'。

總結:TIMESTAMP和DATETIME除了存儲范圍和存儲方式不一樣,沒有太大區別。當然,對于跨時區的業務,TIMESTAMP更為合適。

三、關于TIMESTAMP和DATETIME的自動初始化和更新

首先,我們先看一下下面的操作

mysql> create table test(id int,hiredate timestamp);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into test(id) values(1);
Query OK, 1 row affected (0.00 sec)

mysql> select * from test;
+------+---------------------+
| id  | hiredate      |
+------+---------------------+
|  1 | 2015-12-08 14:34:46 |
+------+---------------------+
1 row in set (0.00 sec)

mysql> show create table test\G
*************************** 1. row ***************************
    Table: test
Create Table: CREATE TABLE `test` (
 `id` int(11) DEFAULT NULL,
 `hiredate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

看起來是不是有點奇怪,我并沒有對hiredate字段進行插入操作,它的值自動修改為當前值,而且在創建表的時候,我也并沒有定義“show create table test\G”結果中顯示的“ DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP”。

其實,這個特性是自動初始化和自動更新(Automatic Initialization and Updating)。

自動初始化指的是如果對該字段(譬如上例中的hiredate字段)沒有顯性賦值,則自動設置為當前系統時間。

自動更新指的是如果修改了其它字段,則該字段的值將自動更新為當前系統時間。

它與“explicit_defaults_for_timestamp”參數有關。

默認情況下,該參數的值為OFF,如下所示:

mysql> show variables like '%explicit_defaults_for_timestamp%';
+---------------------------------+-------+
| Variable_name          | Value |
+---------------------------------+-------+
| explicit_defaults_for_timestamp | OFF  |
+---------------------------------+-------+
1 row in set (0.00 sec)

下面我們看看官檔的說明:

By default, the first TIMESTAMP column has both DEFAULT CURRENT_TIMESTAMP and ON UPDATE CURRENT_TIMESTAMP if neither is specified explicitly。

很多時候,這并不是我們想要的,如何禁用呢?

1. 將“explicit_defaults_for_timestamp”的值設置為ON。

2. “explicit_defaults_for_timestamp”的值依舊是OFF,也有兩種方法可以禁用

     1> 用DEFAULT子句該該列指定一個默認值

     2> 為該列指定NULL屬性。

如下所示:

mysql> create table test1(id int,hiredate timestamp null);
Query OK, 0 rows affected (0.01 sec)

mysql> show create table test1\G
*************************** 1. row ***************************
    Table: test1
Create Table: CREATE TABLE `test1` (
 `id` int(11) DEFAULT NULL,
 `hiredate` timestamp NULL DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

mysql> create table test2(id int,hiredate timestamp default 0);
Query OK, 0 rows affected (0.01 sec)

mysql> show create table test2\G
*************************** 1. row ***************************
    Table: test2
Create Table: CREATE TABLE `test2` (
 `id` int(11) DEFAULT NULL,
 `hiredate` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00'
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

在MySQL 5.6.5版本之前,Automatic Initialization and Updating只適用于TIMESTAMP,而且一張表中,最多允許一個TIMESTAMP字段采用該特性。從MySQL 5.6.5開始,Automatic Initialization and Updating同時適用于TIMESTAMP和DATETIME,且不限制數量。

參考:

1. http://dev.mysql.com/doc/refman/5.6/en/datetime.html

2. http://dev.mysql.com/doc/refman/5.6/en/timestamp-initialization.html

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Mysql數據庫中datetime、bigint、timestamp來表示時間選擇,誰來存儲時間效率最高
  • Mysql中的Datetime和Timestamp比較
  • 淺談mysql導出表數據到excel關于datetime的格式問題
  • python3實現往mysql中插入datetime類型的數據
  • mysql datetime查詢異常問題解決
  • MySql用DATE_FORMAT截取DateTime字段的日期值
  • MySQL時間字段究竟使用INT還是DateTime的說明
  • MySQL 5.6 中TIMESTAMP with implicit DEFAULT value is deprecated錯誤
  • mysql之TIMESTAMP(時間戳)用法詳解
  • MySQL錯誤TIMESTAMP column with CURRENT_TIMESTAMP的解決方法
  • 解析mysql中UNIX_TIMESTAMP()函數與php中time()函數的區別
  • MySQL 中 datetime 和 timestamp 的區別與選擇

標簽:來賓 陽江 黃石 河北 煙臺 赤峰 果洛 鞍山

巨人網絡通訊聲明:本文標題《MySQL中datetime和timestamp的區別及使用詳解》,本文關鍵詞  MySQL,中,datetime,和,timestamp,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL中datetime和timestamp的區別及使用詳解》相關的同類信息!
  • 本頁收集關于MySQL中datetime和timestamp的區別及使用詳解的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产黄色片在线免费观看| 国产乱子伦一区二区三区国色天香| 激情综合色播五月| 性欧美丰满熟妇xxxx性仙踪林| 欧美在线观看视频在线| 一区免费观看视频| 福利视频网站一区二区三区| www亚洲色图| 精品成人a区在线观看| 日本一道高清亚洲日美韩| 91免费看视频| 色婷婷一区二区三区四区| 中文字幕中文字幕中文字幕亚洲无线| 国产一区二区影院| 国产精品1区2区3区4区| 国产三级精品三级| 国产精品香蕉一区二区三区| 成人性生交大片免费看无遮挡aⅴ| 久久综合五月天婷婷伊人| 久久成人久久爱| 欧美午夜激情影院| 久久久久久一级片| 国产精品乡下勾搭老头1| 欧美另类videoxo高潮| 亚洲欧洲日韩av| 99精品一区二区三区| 91久久精品日日躁夜夜躁欧美| 亚洲欧美激情在线| 91蜜桃网址入口| 欧美日韩大陆一区二区| 欧美在线视频日韩| 欧美综合亚洲图片综合区| 亚洲欧洲av色图| 宇都宫紫苑在线播放| 在线免费av一区| 香蕉加勒比综合久久| 亚洲国产综合视频| 日韩欧美国产午夜精品| 免费精品视频最新在线| 一级特黄曰皮片视频| 亚洲国产成人私人影院tom| 成人av影院在线| 欧美三区在线视频| 日韩在线a电影| 成人在线手机视频| 成人免费在线观看入口| 成年女人免费视频| 精品99999| 国产成人综合在线播放| 日本道精品一区二区三区| 午夜精品在线视频一区| 成人无码av片在线观看| 国产精品久久一级| 制服丝袜av在线| 久久久久久久性| 不卡一区二区中文字幕| 3atv在线一区二区三区| 国内不卡的二区三区中文字幕| 中文在线字幕在线观看| 天天综合色天天综合| av资源在线免费观看| 亚洲老司机在线| 免费a在线观看播放| 国产亚洲一区字幕| 日本人dh亚洲人ⅹxx| 精品国产91乱码一区二区三区| www.日韩精品| 日韩精品中文字幕在线一区| 成人免费看片app下载| 精品一区二区三区久久| 国产精品无码久久久久一区二区| 国产精品欧美极品| 国产激情视频网站| 国产精品免费网站在线观看| 日韩Av无码精品| 国产精品乱码一区二三区小蝌蚪| 久久久久亚洲无码| 国产精品久久久久aaaa樱花| 影音先锋黄色资源| 中文字幕亚洲欧美在线不卡| 人妻精品久久久久中文字幕| 日韩理论电影院| 久久视频精品在线观看| 亚洲一区二区三区四区在线观看| 亚洲不卡的av| 日日欢夜夜爽一区| 色欧美日韩亚洲| 黄一区二区三区| 欧美精品aⅴ在线视频| 高清beeg欧美| 亚洲精品在线免费播放| 日本精品一二三| 中文字幕亚洲精品在线观看| 真实乱视频国产免费观看| 亚洲国产一区在线观看| 无码人妻精品中文字幕| 亚洲h动漫在线| 色网综合在线观看| 国产精品亚洲专一区二区三区| 欧美二区乱c少妇| 亚洲国产精品精华液ab| 日本不卡视频一区| 亚洲免费av网站| 国产天堂av在线| 国模套图日韩精品一区二区| 一本色道久久综合亚洲精品按摩| 激情小说亚洲一区| 日韩欧美的一区二区| 宅男噜噜噜66一区二区66| 国产**成人网毛片九色 | 午夜电影网一区| 欧美人禽zoz0强交| 国产一区二区三区日韩| 精品少妇一区二区三区在线播放 | 欧美极品aⅴ影院| 91中文字幕永久在线| 亚洲成人黄色影院| 欧美亚洲高清一区| 91亚洲精品一区二区乱码| 国产精品久久久久久久久图文区| 妺妺窝人体色WWW精品| 免费在线看一区| 日韩欧美亚洲一区二区| 欧美xxxxx精品| 亚洲成人精品一区| 欧美福利视频一区| 一级黄色免费视频| 亚洲成人av电影| 欧美美女喷水视频| 99re热这里只有精品视频| 中文字幕中文在线不卡住| 小向美奈子av| 国产成人亚洲综合色影视| 日本一区二区三级电影在线观看| 亚洲天堂最新地址| 国产精品自产自拍| 国产精品网站导航| 麻豆明星ai换脸视频| 国产成人精品1024| 日韩影视一区二区三区| 中文字幕 久热精品 视频在线| 国产又黄又粗又猛又爽的| 国产a精品视频| 中文字幕五月欧美| 欧美亚洲免费在线一区| 欧美日韩一区二区区别是什么| 亚洲综合免费观看高清完整版 | 韩国在线一区二区| 国产色一区二区| www欧美com| 99久精品国产| 五月婷婷综合激情| 精品少妇一区二区| 女人十八毛片嫩草av| 国产成人av电影在线| 亚洲视频在线一区观看| 欧美写真视频网站| 亚洲一区二区三区综合| 韩国v欧美v日本v亚洲v| 国产精品网曝门| 欧美性xxxxx极品少妇| 中文视频在线观看| 精一区二区三区| 国产精品免费av| 欧美视频在线不卡| bt欧美亚洲午夜电影天堂| 亚洲国产精品久久人人爱| 精品欧美黑人一区二区三区| 五月婷婷欧美激情| 99久久亚洲一区二区三区青草| 亚洲国产另类精品专区| 精品欧美一区二区久久| 亚洲一级二级片| 欧美成人精品一区二区综合免费| 久久99国产精品久久99| 中文字幕日韩欧美一区二区三区| 欧美日韩国产成人在线免费| 法国空姐电影在线观看| 中文av一区特黄| 性久久久久久久久久| 国模少妇一区二区三区| 亚洲视频电影在线| 日韩欧美一区中文| 农村黄色一级片| 特级西西人体4444xxxx| 国产不卡视频一区二区三区| 亚洲一区二区欧美激情| 精品久久久久久久久久久久久久久| 国产精品视频看看| 蜜臀av粉嫩av懂色av| 国产精品一区二区无线| 亚洲一区二区三区四区在线免费观看| 久久久精品国产99久久精品芒果 | 久久精品国产免费| 亚洲欧美日韩国产另类专区| 日韩欧美中文字幕一区| 一本在线高清不卡dvd| 久久精品国产亚洲av久| 91性感美女视频| 国产一区免费电影|