我需要在注册表中添加一个字段 - 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/