婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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的區別及使用詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日本不卡中文字幕| 久久精品人人做人人综合| 亚洲国产日韩在线一区模特| 精品久久五月天| 91在线免费播放| 国产一区二区主播在线| 一区二区日韩av| 中文字幕在线一区二区三区| 亚洲精品一区二区三区四区高清| 欧美日韩一级二级| 在线观看欧美精品| 欧美日韩在线不卡| 欧美日本一区二区在线观看| 欧美午夜精品久久久| 欧美午夜精品一区| 欧美日韩一区在线| 欧美午夜影院一区| 欧美自拍偷拍午夜视频| 欧美日韩国产精品成人| 欧美日韩午夜影院| 欧美一区二区三区视频在线观看 | 中文字幕第一区二区| 精品国产免费人成电影在线观看四季 | 国产成人在线网站| 国产精品白丝av| www.欧美.com| 在线视频你懂得一区二区三区| 成人99免费视频| 粉嫩av亚洲一区二区图片| 91视视频在线直接观看在线看网页在线看 | 久久影视一区二区| 国产精品毛片久久久久久久| 国产精品美女久久久久aⅴ国产馆| 国产精品九色蝌蚪自拍| 亚洲一区二区三区中文字幕| 午夜久久电影网| 久久精品av麻豆的观看方式| 国产成人综合网| 欧美午夜精品一区二区蜜桃| 日韩欧美亚洲一区二区| 国产精品污www在线观看| 亚洲女同女同女同女同女同69| 午夜久久久久久久久久一区二区| 久久国产剧场电影| 91丨国产丨九色丨pron| 欧美日韩小视频| 久久久久青草大香线综合精品| 国产精品久久久久久户外露出 | 亚洲人成在线观看一区二区| 亚洲大片免费看| 国产真实乱对白精彩久久| 91丨porny丨首页| 日韩欧美电影一二三| √…a在线天堂一区| 日本伊人色综合网| jlzzjlzz亚洲日本少妇| 欧美一区二区久久久| 国产精品对白交换视频| 久久国产三级精品| 欧洲一区二区三区在线| 久久日一线二线三线suv| 一卡二卡欧美日韩| 国产ts人妖一区二区| 在线播放视频一区| 国产精品色一区二区三区| 青青草精品视频| 欧洲一区在线观看| 国产精品美女久久久久久久| 免费久久精品视频| 99精品视频在线观看免费| 欧美精品乱码久久久久久按摩 | 日韩成人免费看| 99久久精品费精品国产一区二区| 欧美成人精精品一区二区频| 一区二区三区电影在线播| 波多野结衣在线一区| 国产亚洲一区字幕| 久久99精品网久久| 欧美高清精品3d| 一区二区三区日韩| 成人18视频日本| 国产精品丝袜一区| 国产乱人伦偷精品视频免下载| 91精品欧美综合在线观看最新| 一区二区在线免费观看| www.亚洲激情.com| 亚洲欧美综合网| www.亚洲国产| 国产精品色呦呦| 97久久精品人人做人人爽| 国产精品你懂的| 国产suv精品一区二区三区| 久久综合99re88久久爱| 国产精品亚洲视频| 亚洲国产成人自拍| 国产成人免费高清| 亚洲欧洲一区二区三区| caoporn国产精品| 亚洲日穴在线视频| 色噜噜狠狠色综合欧洲selulu| 亚洲精品伦理在线| 欧美日韩一区二区在线观看 | 成人免费视频网站在线观看| 久久精品人人做人人综合| 成人一级片在线观看| 国产精品卡一卡二卡三| 色婷婷久久一区二区三区麻豆| 亚洲欧美色综合| 99久久99久久精品国产片果冻 | 久久99精品久久久| 久久一区二区三区国产精品| 国产麻豆视频精品| 久久久久久**毛片大全| 成人免费观看男女羞羞视频| 亚洲欧美日韩国产成人精品影院 | 99久久婷婷国产综合精品| 亚洲欧美激情在线| 欧美日韩中文字幕精品| 日本欧美一区二区三区| 国产农村妇女精品| 色婷婷久久久综合中文字幕| 免费精品99久久国产综合精品| 欧美精品一区二区三区蜜桃| 色综合久久66| 热久久一区二区| 中文字幕亚洲视频| 日韩一本二本av| 国产成人精品影视| 亚洲一区二区视频在线| 国产亚洲欧美在线| 欧美日本韩国一区二区三区视频| 裸体歌舞表演一区二区| 国产在线精品免费av| 国内精品第一页| 日韩欧美电影一二三| 国产精品美女久久久久久久网站| 亚洲一区二区影院| 91在线观看视频| 日韩欧美在线综合网| 日韩久久一区二区| 丰满放荡岳乱妇91ww| 91精品国产综合久久精品| 欧美国产乱子伦| 日韩福利电影在线观看| 天天综合色天天综合色h| 国产婷婷色一区二区三区在线| av网站一区二区三区| 色乱码一区二区三区88| 91超碰这里只有精品国产| 久久97超碰色| 综合久久国产九一剧情麻豆| 日本韩国一区二区| 狠狠色丁香婷婷综合| 一区二区在线观看免费视频播放| wwwwxxxxx欧美| 欧美丰满美乳xxx高潮www| 91在线小视频| 成人免费看黄yyy456| 另类调教123区| 婷婷夜色潮精品综合在线| 国产精品看片你懂得| 国产色综合一区| 欧美不卡一二三| 欧美色综合网站| 久久99精品久久久久久动态图 | 最新欧美精品一区二区三区| 国产精品国产三级国产aⅴ中文| 综合色天天鬼久久鬼色| 亚洲国产中文字幕在线视频综合| 午夜天堂影视香蕉久久| 精一区二区三区| av午夜精品一区二区三区| 在线免费观看一区| 精品精品国产高清a毛片牛牛| 国产精品久久久久久久裸模| 亚洲成av人片一区二区| 黄页视频在线91| 91免费看`日韩一区二区| 欧美一区二区三级| 国产精品成人在线观看| 免费在线看成人av| 成人黄色片在线观看| 91精品在线免费观看| 亚洲欧洲日韩在线| 日本不卡一区二区三区| av在线不卡电影| 欧美大尺度电影在线| 综合色天天鬼久久鬼色| 黑人巨大精品欧美一区| 欧美视频在线一区二区三区| 97se亚洲国产综合自在线观| 欧美一区三区四区| 亚洲手机成人高清视频| 欧美理论片在线| 精品卡一卡二卡三卡四在线| 亚洲猫色日本管| 国产乱子伦视频一区二区三区| 一本大道久久a久久精品综合| 欧美成人精品3d动漫h| 一区二区三区在线观看欧美|