CURRENT_DATE/CURDATE() not working as default DATE value(CURRENT_DATE/CURDATE() 不作为默认 DATE 值工作)
问题描述
这里很直接的问题,我认为这应该有效,但它没有.为什么不呢?
Pretty straight forward question here, I think this should work but it doesn't. Why doesn't it?
CREATE TABLE INVOICE(
INVOICEDATE DATE NOT NULL DEFAULT CURRENT_DATE
)
推荐答案
它不起作用,因为它不受支持
It doesn't work because it's not supported
DEFAULT 子句指定列的默认值.除了一个例外,默认值必须是一个常量;它不能是函数或表达式.这意味着,例如,您不能将日期列的默认值设置为诸如 NOW() 或 CURRENT_DATE 之类的函数的值.例外是您可以将 CURRENT_TIMESTAMP 指定为 TIMESTAMP 列的默认值
The
DEFAULTclause specifies a default value for a column. With one exception, the default value must be a 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 asNOW()orCURRENT_DATE. The exception is that you can specifyCURRENT_TIMESTAMPas the default for aTIMESTAMPcolumn
http://dev.mysql.com/doc/refman/5.5/en/create-table.html
这篇关于CURRENT_DATE/CURDATE() 不作为默认 DATE 值工作的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:CURRENT_DATE/CURDATE() 不作为默认 DATE 值工作
基础教程推荐
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- 在多列上分布任意行 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- oracle区分大小写的原因? 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
