mysql - 在表中添加一个字段并检查另一列的条件

标签 mysql alter

我需要在注册表中添加一个字段 - DOC,日期类型,并确保 DOC 大于 DOJ。我尝试过这个

ALTER TABLE Registration
ADD DOC date
CHECK (DOC>DOJ);

它显示错误。我哪里出错了?

最佳答案

首先,prior to MySQL version 8.0.16 ,MySQL 只允许非常有限的表 CHECK 约束语法,该语法会被解析并忽略。因此,如果您的 MySQL 版本 <8.0.16,那么您的 ALTER TABLE 语句将无法实现任何目的;也可能是语法错误的原因。

现在,如果您的版本确实正确;那么您错误地定义了表约束。根据Documentation :

A CHECK constraint is specified as either a table constraint or column constraint:

  • A table constraint does not appear within a column definition and can refer to any table column or columns. Forward references are permitted to columns appearing later in the table definition.

  • A column constraint appears within a column definition and can refer only to that column.

由于您的 CHECK 约束涉及多个列,因此它是一个表约束。另外,ALTER TABLE syntax添加新的 CHECK 约束如下:

ALTER TABLE tbl_name
    ADD CONSTRAINT [symbol] CHECK (expr) [[NOT] ENFORCED];

请尝试以下操作:

ALTER TABLE Registration
ADD DOC date, 
ADD CONSTRAINT chk_doc_greater_doj CHECK (DOC>DOJ);

关于mysql - 在表中添加一个字段并检查另一列的条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57008114/

相关文章:

php - 预测/纠正全文搜索

postgresql - 使用 plpgsql 将列 bytea 更改为各种版本的 Postgres 中的文本

mysql - 在 MySQL 5.7.22 中尝试使用 ENCRYPTION = "Error parsing DDL"( key 环插件)更改表时出现错误 'Y'

oracle - 向 oracle 中的现有表添加一个具有默认值的列

mysql - 有没有办法将规范化数据选回一个结果集中

MySQL过滤每个项目最后一个用户的第一个日期

MySQL Workbench,如何修复 "SELECT is not valid at this position for this server version"错误

mysql - 使用 JDBC 从任何计算机访问 localhost 数据库

Mysql 根据外键的存在改变表时间

mysql - 当我运行 TIME_TO_SEC 来修改 GENERATED 列时,它会抛出错误,尽管 TIME_TO_SEC 在 SELECT 语句中独立工作正常