国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL 5.6 中 TIMESTAMP 的變化分析

2020-01-18 22:47:27
字體:
來源:轉載
供稿:網友

在MySQL 5.6.6之前,TIMESTAMP的默認行為:

■TIMESTAMP列如果沒有明確聲明NULL屬性,默認為NOT NULL。(而其他數據類型,如果沒有顯示聲明為NOT NULL,則允許NULL值。)設置TIMESTAMP的列值為NULL,會自動存儲為當前timestamp。
■表中的第一個TIMESTAMP列,如果沒有聲明NULL屬性、DEFAULT或者 ON UPDATE,會自動分配 DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP 屬性。
■表中第二個TIMESTAMP列,如果沒有聲明為NULL或者DEFAULT子句,默認自動分配'0000-00-00 00:00:00′。插入行時沒有指明改列的值,該列默認分配'0000-00-00 00:00:00′,且沒有警告。

2列TIMESTAMP未聲明為NULL的默認行為

從MySQL5.6.6開始這種默認設置的方法被廢棄了。在MySQL啟動時會出現以下警告:

[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (seedocumentation for more details).

關閉警告,在my.cnf中加入

[mysqld] explicit_defaults_for_timestamp=true 

重啟MySQL后錯誤消失,這時TIMESTAMP的行為如下:

■TIMESTAMP如果沒有顯示聲明NOT NULL,是允許NULL值的,可以直接設置改列為NULL,而沒有默認填充行為。
■TIMESTAMP不會默認分配DEFAULT CURRENT_TIMESTAMP 和 ON UPDATE CURRENT_TIMESTAMP屬性。

TIMESTAMP 不設置是否為NULL

■聲明為NOT NULL且沒有默認子句的TIMESTAMP列是沒有默認值的。往數據表中插入列,又沒有給TIMESTAMP列賦值時,如果是嚴格SQL模式,會拋出一個錯誤,如果嚴格SQL模式沒有啟用,該列會賦值為'0000-00-00 00:00:00′,同時出現一個警告。(這和MySQL處理其他時間類型數據一樣,如DATETIME)

TIMESTAMP 默認設置為NOT NULL

Note:

以上內容和存儲引擎選擇無關。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 汝阳县| SHOW| 凤台县| 陆丰市| 白朗县| 顺昌县| 明水县| 墨竹工卡县| 青龙| 大悟县| 康马县| 宁波市| 漳平市| 黄骅市| 台南县| 泸水县| 长沙县| 辉南县| 连山| 清新县| 衡水市| 宣恩县| 林西县| 揭东县| 武邑县| 扬中市| 夏邑县| 金堂县| 海晏县| 承德市| 峨边| 宁强县| 合川市| 庐江县| 泰州市| 大新县| 竹北市| 邢台县| 扎兰屯市| 扎兰屯市| 霍林郭勒市|