mysql8.0支持CURRENT_DATE如何写

背景:

新功能,要在原有的基础表上添加一个时间字段,只到月即可,我选择使用date字段,并且默认值是当前时间。SQL如下

复制代码
alter table test.location_conf add effective_month DATE default CURRENT_DATE not null COMMENT '规则生效月份';

会报错

复制代码
SQL 错误 [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 'CURRENT_DATE not null COMMENT '经办规则生效月份'' at line 1

问了百度Baidu Comate也说不出个所以然来,只会给我说什么是对的,让我自己去对比,然而SQL又是一模一样。

分析:

首先这个字段是一定可以用的。从几个方向考虑问题

1.语法错误(按Baidu Comate这个"人工智能"给出的答案,我写的语法是没问题的)

2.权限问题(权限找运维试过了,运维的权限执行SQL也是会报错的)

3.版本问题(MySQL 的某些旧版本可能不支持 CURRENT_DATE 函数,它在 MySQL 5.6.5 及以上版本被引入,我们是8.0.18)

以上都没有问题,这时想mysql8版本是不是会有什么调整,就搜索mysql8 支持CURRENT_DATE

解决:

问题果然是在这个8这个版本,版本8.0.13之后才支持date类型默认值设置为CURRENT_DATE,而且不能直接写需要用括号包起来。

语法不能直接写CURRENT_DATE,只有CURRENT_TIMESTAMP可以直接直接写。(8之前的版本是否可以写,还需要验证)

正确的写法

复制代码
alter table test.location_conf add effective_month1 DATE 
not null
default (curdate())
COMMENT '规则生效月份';

总结:

mysql中,8.0.13版本之后的允许将Date字段的默认值设置为CURRENT_DATE(当前日期),设置CURRENT_DATE默认值,需要将其包裹在圆括号内,以区分常量默认值,否则将报语法错误。

参考文档:mysql官网文档

mysql 将date字段默认值设置为CURRENT_DATE - 墨天轮

相关推荐
倔强的石头_12 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端