mysql如何建立索引workbench_在用 MySQL Workbench (MySQL5.6) 创建 外键 时遇到的问题

在使用MySQL Workbench创建外键时,遇到PERSON_ID字段无法创建外键的问题。原因是PERSON表的PERSON_ID字段有UNSIGNED属性而关联表person_event中没有。解决方法是将PERSON_EVENT表的PERSON_ID字段添加UNSIGNED属性,然后可以成功创建外键。创建外键过程包括添加索引和约束,确保外键字段属性与主表主键一致且NOT NULL。
摘要由CSDN通过智能技术生成

表结构与关系:_____________ __________________

| | | | _____________

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值