亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql實(shí)現(xiàn)將date字段默認(rèn)值設(shè)置為CURRENT_DATE

 更新時(shí)間:2023年07月24日 10:07:34   作者:PostgreSQL運(yùn)維技術(shù)  
這篇文章主要介紹了mysql實(shí)現(xiàn)將date字段默認(rèn)值設(shè)置為CURRENT_DATE問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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ò)誤。

參考文檔: https://dev.mysql.com/doc/refman/8.0/en/data-type-defaults.html https://stackoverflow.com/questions/20461030/current-date-curdate-not-working-as-default-date-value/54119983#54119983

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ù)備份腳本

    本篇文章教給大家用shell寫一個(gè)mysql數(shù)據(jù)備份腳本,這是一個(gè)簡(jiǎn)單備份MYSQL數(shù)據(jù)庫(kù)的方法,一起跟著學(xué)習(xí)下吧。
    2017-12-12
  • Mysql時(shí)區(qū)的幾種問題及解決方法

    Mysql時(shí)區(qū)的幾種問題及解決方法

    在使用MySQL時(shí),時(shí)區(qū)設(shè)置容易引發(fā)一些錯(cuò)誤,本文將介紹MySQL時(shí)區(qū)問題可能引發(fā)的錯(cuò)誤,并提供一些解決方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • mysql命令行下用戶管理方法分享

    mysql命令行下用戶管理方法分享

    如果有mysql管理工具phpmyadmin的話,我們可以通過圖形畫界面來對(duì)用戶進(jìn)行管理,但是如果沒有phpmyadmin這樣的管理工具怎么辦呢
    2012-07-07
  • 將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法

    將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法

    今天小編就為大家分享一篇關(guān)于將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql缺少my.ini文件的解決方法

    mysql缺少my.ini文件的解決方法

    使用的這么長(zhǎng)時(shí)間的mysql,有一天我突然需要使用mysql?的配置文件my.ini時(shí)發(fā)現(xiàn)沒有這個(gè)文件并且這個(gè)文件不是被隱藏了,所以本文給大家介紹了mysql缺少my.ini文件的解決方法,需要的朋友可以參考下
    2023-12-12
  • 手把手教你使用Navicat查詢表的詳細(xì)結(jié)構(gòu)

    手把手教你使用Navicat查詢表的詳細(xì)結(jié)構(gòu)

    在使用Navicat時(shí),我們可以通過執(zhí)行一些SQL語句來查看表結(jié)構(gòu),下面這篇文章主要給大家介紹了關(guān)于如何使用Navicat查詢表的詳細(xì)結(jié)構(gòu),文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • mysql學(xué)習(xí)筆記之基礎(chǔ)知識(shí)

    mysql學(xué)習(xí)筆記之基礎(chǔ)知識(shí)

    本文是MySQL學(xué)習(xí)筆記系列文章的第一篇,給大家簡(jiǎn)單講解下MySQL的一些檢查操作命令,希望大家能夠喜歡
    2017-02-02
  • Mysql ERROR 1577錯(cuò)誤解決方法

    Mysql ERROR 1577錯(cuò)誤解決方法

    這篇文章主要介紹了Mysql ERROR 1577錯(cuò)誤解決方法,一般是在升級(jí)mysql后會(huì)發(fā)生這個(gè)錯(cuò)誤,錯(cuò)誤原因是需要升級(jí)MySQL系統(tǒng)表,需要的朋友可以參考下
    2014-08-08
  • 詳解DBeaver連接MySQL8以上版本以及解決可能遇到的問題

    詳解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以及Squel Pro

    給大家講述一下如何在MAC蘋果系統(tǒng)上配置MYSQL數(shù)據(jù)庫(kù)以及Squel Pro的方法。
    2017-11-11

最新評(píng)論