数据库使用 mysql 8.0.16
管理工具使用 Navicat
CREATE TABLE
IF
NOT EXISTS `Table2` (
`id` BIGINT NOT NULL AUTO_INCREMENT,
`Attribute1` datetime NOT NULL DEFAULT ( CURRENT_TIMESTAMP ),
`Attribute2` date NOT NULL DEFAULT ( CURRENT_DATE ),
`Attribute3` datetime NULL,
`Attribute4` date NULL,
`created_time` datetime NULL,
`updated_time` datetime NULL,
`created_by` BIGINT NULL,
`updated_by` BIGINT NULL,
PRIMARY KEY ( Id ));
Attribute1 是 datetime 类型 默认值使用了函数 CURRENT_TIMESTAMP
Attribute2 是 date 类型 使用默认值函数 CURRENT_DATE ,都是必填
SHOW FULL COLUMNS FROM `table2`
可以看到 Attribute1 的默认值变成了 now() Attribute2 的默认值变成了 curdate()
我很疑惑 为什么 默认值 换了函数?
ALTER TABLE`table2`
ADD INDEX `111`(`Attribute1`, `Attribute2`);
> 1067 - Invalid default value for 'Attribute1'
> 时间: 0.002s
在这 2 个字段上加索引会报错 错误的默认值
ALTER TABLE `rcpr_rd1_aa1_b`.`table2`
MODIFY COLUMN `Attribute1` datetime NOT NULL DEFAULT (CURRENT_TIMESTAMP) AFTER `id`,
MODIFY COLUMN `Attribute2` date NOT NULL DEFAULT (CURRENT_DATE) AFTER `Attribute1`,
ADD INDEX `121`(`Attribute1`, `Attribute2`);
此时 我直接修改 这 2 个字段的类型 并直接加上 索引
挺神奇的,居然没报错,索引也加上去了。
mysql 的那两个默认值为什么会变
为什么加索引提示错误默认值
修改字段语句和加索引语句放一起为什么又没报错
1
asmile1993 2022-09-20 11:42:37 +08:00
Q1: mysql 的那两个默认值为什么会变
CURRENT_TIMESTAMP and CURRENT_TIMESTAMP() are synonyms for NOW(). CURRENT_DATE and CURRENT_DATE() are synonyms for CURDATE(). Q2: 为什么加索引提示错误默认值 执行成功了,你是不是分别有 Table2 和 table2 这两张表?看看自己的 lower_case_table_names 参数是否为 0 |
2
leegradyllljjjj 2022-09-20 11:55:27 +08:00
1. 那不是默认值,那是默认的取值函数;
2. show variables where Variable_name in ('lower_case_table_names'); 看看是否区分表名大小写; 3. 同 2 顺便吐槽一下:有些高版本的 mysql 驱动是真的坑人啊 |
3
coderstory OP @asmile1993 代码贴的有问题 都是 table2
``` ALTER TABLE `table2` ADD INDEX `111`(`Attribute1`, `Attribute2`); ALTER TABLE `table2` MODIFY COLUMN `Attribute1` datetime NOT NULL DEFAULT (CURRENT_TIMESTAMP) AFTER `id`, MODIFY COLUMN `Attribute2` date NOT NULL DEFAULT (CURRENT_DATE) AFTER `Attribute1`, ADD INDEX `12111`(`Attribute1`, `Attribute2`); ``` 第二个没报错 |
4
coderstory OP |
5
asmile1993 2022-09-20 14:03:06 +08:00
@coderstory 我的版本是 8.0.26 ,加索引操作没问题
|
6
nothingistrue 2022-09-20 14:30:08 +08:00
根源:SQL 本身就是弱类型语言,MYSQL 又是特别“聪明”的数据库,所以会比 HTML 、JavaScript 这些语言更变态的自动纠错。
对于你的问题,CREATE TABLE 、ALTER TABLE 、ADD INDEX 这些,只是一次性的动态执行语句,它们不是数据库物理模型的最终的定义语句。故,类型不一样,同样的逻辑有些能执行有些不能执行,这都是正常情况。 最后提一点,对于日期时间、或者时间戳类型,建议不要在数据库上设置默认值,坑太多。NOT NULL 但是没有默认值,这是允许的。 |
7
coderstory OP |
8
coderstory OP @nothingistrue 做的是低代码平台 这些表都是用户设计的 表操作的逻辑也是动态生成的。
最终执行的 SQL 很难插入相关字段的默认值 TAT |
9
9y7cz863P00C7Lie 2022-09-20 16:12:11 +08:00
8.0.25 测试加索引操作没问题,估计是中间修复了某些 bug 吧
|
10
julyclyde 2022-09-21 08:56:42 +08:00
@nothingistrue not null 但没有默认值
那如果没有写值,读出来是啥内容呢? |