表结构与关系

_____________        __________________
|             |      |                  |       _____________
|   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_IDUNSIGNED这条属性(关联表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为宜。