mysql實(shí)現(xiàn)將date字段默認(rèn)值設(shè)置為CURRENT_DATE
mysql將date字段默認(rèn)值設(shè)置為CURRENT_DATE
我們是否可以在mysql中,將Date字段的默認(rèn)值設(shè)置為CURRENT_DATE(當(dāng)前日期)?
答案是8.0之前不可以,8.0.13之后可以。
比如在5.7版本中使用如下sql創(chuàng)建表,將會(huì)提示語法錯(cuò)誤:
CREATE TABLE `t_order` ( `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主鍵', `create_time` date DEFAULT (curdate()), PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
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 '(curdate()), PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4' at line 3
官方文檔中,有如下描述:
With one exception, the default value specified in a DEFAULT clause must be a literal constant; it cannot be a function or an expression. This means, for example, that you cannot set the default for a date column to be the value of a function such as NOW() or CURRENT_DATE. The exception is that, for TIMESTAMP and DATETIME columns, you can specify CURRENT_TIMESTAMP as the default. See Section 11.2.5, “Automatic Initialization and Updating for TIMESTAMP and DATETIME”.
文檔地址:https://dev.mysql.com/doc/refman/8.0/en/data-type-defaults.html
Date字段不能指定默認(rèn)值now()或者CURRENT_DATE,但是我們可以使用TIMESTAMP或者DATETIME字段,指定默認(rèn)值為CURRENT_TIMESTAMP。
但是從8.0.13版本開始可以指定DATE的默認(rèn)值為的CURRENT_DATE。
需要注意的是指定CURRENT_DATE為默認(rèn)值時(shí),需要用括號(hào)() 包裹住CURRENT_DATE,但是timestamp或者datetime字段則不需要。
例如,
CREATE TABLE t (d DATETIME DEFAULT CURRENT_TIMESTAMP);
這是合法的。
然后CURRENT_DATE需要用括號(hào)包裹。
CREATE?TABLE?t?(d?DATE?DEFAULT?(CURRENT_DATE));
因?yàn)閐efault子句中指定的默認(rèn)值通常是常量或者表達(dá)式。
但是,需要將表達(dá)式默認(rèn)值括在圓括號(hào)內(nèi),以區(qū)別常量默認(rèn)值。
The default value specified in a DEFAULT clause can be a literal constant or an expression. With one exception, enclose expression default values within parentheses to distinguish them from literal constant default values.
例如:
CREATE TABLE t1 ( -- literal defaults i INT DEFAULT 0, c VARCHAR(10) DEFAULT '', -- expression defaults f FLOAT DEFAULT (RAND() * RAND()), b BINARY(16) DEFAULT (UUID_TO_BIN(UUID())), d DATE DEFAULT (CURRENT_DATE + INTERVAL 1 YEAR), p POINT DEFAULT (Point(0,0)), j JSON DEFAULT (JSON_ARRAY()) );
注意
mysql中,8.0.13版本之后的允許將Date字段的默認(rèn)值設(shè)置為CURRENT_DATE(當(dāng)前日期),但是之前的版本則不允許。
設(shè)置CURRENT_DATE默認(rèn)值,需要將其包裹在圓括號(hào)內(nèi),以區(qū)分常量默認(rèn)值,否則將報(bào)語法錯(cuò)誤。
mysql設(shè)置datetime字段為空,默認(rèn)值為CURRENT_TIMESTAMP
1.檢查該表中已有行的datetime字段是否有空值,如果有空值,則刪掉該行
一定要檢查!?。?!
2.導(dǎo)出該表的sql語句
3.記事本打開后將datetime類型字段更改為
?`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時(shí)間',
設(shè)置默認(rèn)值為CURRENT_TIMESTAMP
4.最后在將該sql文件導(dǎo)入數(shù)據(jù)庫(kù)中就有非空有默認(rèn)值
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
用shell寫一個(gè)mysql數(shù)據(jù)備份腳本
本篇文章教給大家用shell寫一個(gè)mysql數(shù)據(jù)備份腳本,這是一個(gè)簡(jiǎn)單備份MYSQL數(shù)據(jù)庫(kù)的方法,一起跟著學(xué)習(xí)下吧。2017-12-12將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法
今天小編就為大家分享一篇關(guān)于將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03手把手教你使用Navicat查詢表的詳細(xì)結(jié)構(gòu)
在使用Navicat時(shí),我們可以通過執(zhí)行一些SQL語句來查看表結(jié)構(gòu),下面這篇文章主要給大家介紹了關(guān)于如何使用Navicat查詢表的詳細(xì)結(jié)構(gòu),文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05mysql學(xué)習(xí)筆記之基礎(chǔ)知識(shí)
本文是MySQL學(xué)習(xí)筆記系列文章的第一篇,給大家簡(jiǎn)單講解下MySQL的一些檢查操作命令,希望大家能夠喜歡2017-02-02詳解DBeaver連接MySQL8以上版本以及解決可能遇到的問題
這篇文章主要介紹了DBeaver連接MySQL8以上版本以及解決可能遇到的問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11在Mac系統(tǒng)上配置MySQL以及Squel Pro
給大家講述一下如何在MAC蘋果系統(tǒng)上配置MYSQL數(shù)據(jù)庫(kù)以及Squel Pro的方法。2017-11-11