1

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

这是解释我要做什么的伪代码:

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)
)

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

4

1 回答 1

2

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

使用如何在 MySql 触发器中中止 INSERT 操作中的信息?像这个例子这样的东西应该会有所帮助

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;
于 2013-03-26T13:18:57.003 回答