zhuce 发表于 2018-9-29 10:15:15

在用 MySQL Workbench (MySQL5.6) 创建 外键 时遇到的问题

  表结构与关系:
_____________      __________________  
|             |      |                  |       _____________
  
|   EVENTS    |      |   PERSON_EVENT   |      |             |
  
|_____________|      |__________________|      |    PERSON   |
  
|             |      |                  |      |_____________|
  
| *EVENT_ID   || *EVENT_ID      |      |             |
  
|EVENT_DATE |      | *PERSON_ID       || *PERSON_ID|

  
| >  
|_____________|                              |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为宜。
  


页: [1]
查看完整版本: 在用 MySQL Workbench (MySQL5.6) 创建 外键 时遇到的问题