【MySQL8.0】创建外键时报错:3780

现象描述:

今天在给两个表建立外键约束时,报了3780的错误--具体描述如下:

Referencing column 'COMMENT_ID' and referenced column 'ID' in foreign key constraint 'REP_COM' are incompatible.

意思就是,主表ID和从表的COMMENT_ID这一列不兼容

这里附上两张表此字段的设置,主表:

从表:

解决办法:

资料(《mysql数据库应用案例教程》)提到mysql建立外键约束时应注意的点:

  1. 主表和从表必须使用InnoDB存储引擎

  1. 设置外键约束的字段和关联的主键必须具有相同的数据类型。

  1. 整数类型的大小和符号必须相同;

  1. 字符串类型的长度可以不相同,但对于非二进制字符串,字符集和排序规则必须相同。

根据以上注意点寻找病因,发现从表comment_id字段设置了无符号约束,而主表id字段没有设置,于是将主表id也设置了无符号约束后,再建立外键,成功!!!💅💅💅

  • 6
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL创建外键有多种方法。一种常见的方法是在表的定义中直接添加外键约束。可以使用以下语法来创建外键: ALTER TABLE 子表表名 ADD CONSTRAINT 外键约束名 FOREIGN KEY (子表外键字段名) REFERENCES 主表表名 (主表主键字段名); 例如,如果我们要创建一个名为table_test的表,其中包含一个名为user_id的外键字段,引用了另一个表的user_id字段作为主键,可以使用以下语句创建外键约束: ALTER TABLE table_test ADD CONSTRAINT FK_user_id FOREIGN KEY (user_id) REFERENCES 另一个表名 (user_id); 另外一种方法是在创建表的候直接在表字段后面加上PRIMARY KEY关键字,这样会同创建一个主键和外键约束。例如,可以使用以下语句创建一个带有主键和外键约束的表: CREATE TABLE table_name ( id INT PRIMARY KEY, foreign_key INT, FOREIGN KEY (foreign_key) REFERENCES 另一个表名 (另一个表的主键字段名) ); 请根据具体的需求选择适合的方法来创建外键。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【mysql】给一张表添加外键的四种方法](https://blog.csdn.net/weixin_43431218/article/details/129167709)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值