MySQL 日期类型及默认设置 (除timestamp类型外,系统不支持其它时间类型字段设置默认值)

admin3年前IT技术681

MySQL 日期类型及默认设置  (除timestamp类型外,系统不支持其它时间类型字段设置默认值)

 

MySQL 日期类型及默认设置

之前在用 MySQL 新建 table,创建日期类型列时遇到了一些问题,现在整理下来以供参考。

MySQL 的日期类型如何设置当前时间为其默认值?
答:请使用 timestamp 类型,且 默认值设为 now() 或 current_timestamp() 。



    • 日期类型区别及用途

    • 日期类型的 default 设置

    • 常见的日期获取函数

    • 其他的内容

    • MySQL 日期类型及默认设置


日期类型区别及用途

MySQL 的日期类型有5个,分别是: date、time、year、datetime、timestamp。
将在“菜鸟教程”和百度获取的资料,整理成如下表格:

类型字节格式用途是否支持设置系统默认值
date3YYYY-MM-DD日期值不支持
time3HH:MM:SS时间值或持续时间不支持
year1YYYY年份不支持
datetime8YYYY-MM-DD HH:MM:SS日期和时间混合值不支持
timestamp4YYYYMMDD HHMMSS混合日期和时间,可作时间戳支持

日期类型的 default 设置

关于 default 设置,通常情况下会使用当前时间作为默认值。
Example:

ts_time timestamp NOT NULL DEFAULT NOW();
  • 1

or

ts_time timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP();
  • 1

根据上表可知,除了 timestamp 类型支持系统默认值设置,其他类型都不支持。
如果建表语句中有:

ts_time1 time NOT NULL DEFAULT NOW(); ts_time3 yearNOT NULL DEFAULT NOW(); ts_time2 date NOT NULL DEFAULT CURRENT_TIMESTAMP(); ts_time2 datetime NOT NULL DEFAULT CURRENT_TIMESTAMP();
  • 1

  • 2

  • 3

  • 4

都会报错。所以想要设置某个日期列的默认值为当前时间,只能使用 timestamp 类型,并设置 DEFAULT NOW() 或 DEFAULT CURRENT_TIMESTAMP() 作为默认值。

date 类型默认值使用 current_date() 创建失败

date 创建失败

date 类型默认值使用 now() 创建失败

 date 创建失败2

date 类型默认值使用 current_timestamp() 创建失败

 date 创建失败3

datetime 类型默认值使用 current_timestamp() 创建失败

datetime 创建失败1

datetime 类型默认值使用 now() 创建失败

datetime 创建失败2

timestamp 类型默认值使用 now() 创建成功

timestamp

常见的日期获取函数

MySQL中有一些日期函数可供我们使用,我们可以使用 ” select 函数名() ; ” 的 sql 查看它们的返回值。同时也可以使用 “select 自定义函数名();”,调用我们自己定义的函数。
Eample:

select current_timestamp();
  • 1

MySQL当前时间戳

select current_date();
  • 1

MySQL当前日期

select current_time();
  • 1

当前时间

select now();
  • 1

获取当前时间

 

函数描述
NOW()返回当前的日期和时间
CURDATE()返回当前的日期
CURTIME()返回当前的时间
DATE()提取日期或日期/时间表达式的日期部分
EXTRACT()返回日期/时间按的单独部分
DATE_ADD()给日期添加指定的时间间隔
DATE_SUB()从日期减去指定的时间间隔
DATEDIFF()返回两个日期之间的天数
DATE_FORMAT()用不同的格式显示日期/时间


相关文章

国内主流在用的10大后台UI框架[转]

国内主流在用的10大后台UI框架[转]

前任何企业在开发的过程中,都摆脱不了管理后台的开发需要。 如果一切从0开始,费时费力,而且还存在很大失败的风险。对于国内很多互联网公司来说,不断追求敏捷,快速,一套免费可用UI框架成了必备工...

excel在第三个空格插入数据

=LEFT(RIGHT(C63,LEN(C63)-FIND(" ",C63,FIND(" ",C63,FIND(" ",C63)+1)+1)...

设置apach多站点的配置方法

 Include conf/vhost/*.conf...

哈佛大学凌晨4点半的景象,让你明白什么是距离

哈佛大学凌晨4点半的景象,让你明白什么是距离

       哈佛老师经常给学生这样的告诫:如果你想在进入社会后,在任何时候任何场合下都能得心应手并且得到应有的评价,那么你在哈佛的学习期间...

magento2.x系统加速

magento2.x系统加速

1:在根目录运行以下命令,全站生成静态bin/magento setup:static-content:deploy2:编译整个网站,让网站加速50%  注意事项:要把PHP脚本内存限制设置...

[转]想学流量,有哪些值得推荐的【优质】渠道?

[转]想学流量,有哪些值得推荐的【优质】渠道?

在当今的互联网中,流量的成本越来越贵,获取客户的价格也越来越高,所有做互联网生意的人,都要时刻思考的两点是:第一:我的客户,我的产品曝光要从哪里来?第二:如何以最低的成本,获取有效的客户?当所有人的流...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。