表结构与关系:_____________ __________________
| | | | _____________
| EVENTS | | PERSON_EVENT | | |
|_____________| |__________________| | PERSON |
| | | | |_____________|
| *EVENT_ID | | *EVENT_ID | | |
| EVENT_DATE | | *PERSON_ID | | *PERSON_ID |
| TITLE | |__________________| | AGE |
|_____________| | FIRSTNAME |
| LASTNAME |
|_____________|
遇到问题:
在 MySQL Workbench 为person_event表创建外键的时候发现只有
字段 :EVENT_ID能创建外键,
字段:PERSON_ID不能创建外键,
后来比较了一下person表 和 events表,发现person表中的
字段:PERSON_ID有UNSIGNED这条属性(关联表person_event中字段:PERSON_ID没有UNSIGNED这条属性),去掉后,Apply。
重新修改person_event表,开始创建外键,这回字段:PERSON_ID可以创建外键,
创建外键的时候 Indexes 中会自动加入两条信息,是两条索引,Apply,显示
SQL语句:ALTER TABLE `mytest`.`person_event`
ADD INDEX `person_event_p_id_1_idx` (`PERSON_ID` ASC),
ADD INDEX `person_event_e_id_1_idx` (`EVENT_ID` ASC);
ALTER TABLE `mytest`.`person_event`
ADD CONSTRAINT `person_event_p_id_1`
FOREIGN KEY (`PERSON_ID`)
REFERENCES `mytest`.`person` (`PERSON_ID`)
ON DELETE NO ACTION
ON UPDATE NO ACTION,
ADD CONSTRAINT `person_event_e_id_1`
FOREIGN KEY (`EVENT_ID`)
REFERENCES `mytest`.`events` (`EVENT_ID`)
ON DELETE NO ACTION
ON UPDATE NO ACTION;
首先会创建两条索引,然后添加约束,在约束中添加外键,指定本表中外键字段,指定参考表中的字段,最后设置外键选项。
总结:
创建关联表时,关联表的外键字段属性最好与主表主键字段属性一致,并设置成NOT NULL为宜。