MySQL:使用计算约束创建表

时间:2013-03-26 13:16:05

标签: mysql sql key

创建表时,是否可以根据两列的计算值声明约束?

这是psuedo代码,解释了我正在尝试做的事情:

CREATE TABLE employee_comments(
  id int(11),
  user_id int(11),
  franchise_branch_id int(11) default 0,
  corporate_branch_id int(11) default 0,
  primary key id,
  key corp_xor_franch(corporate_branch_id + franchise_branch_id > 0)
)

基本上,用户在公司级别或特许经营级别插入评论。根据评论,任何一个都可以留空,但至少必须声明一个。

1 个答案:

答案 0 :(得分:2)

您最好的选择可能是使用TRIGGER - mysql文档http://dev.mysql.com/doc/refman/5.0/en/create-trigger.html

使用How to abort INSERT operation in MySql trigger?中的信息,例如此示例应该有帮助

CREATE TRIGGER checkFieldsValid 
BEFORE INSERT ON employee_comments
FOR EACH ROW BEGIN

    DECLARE errmsg VARCHAR(255) DEFAULT "REQUIRED DATA NOT FOUND";

    IF NOT NEW.franchise_branch_id = 0 XOR NEW.corporate_branch_id = 0 THEN

        SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = errmsg;

    END IF;
END;