MySQL添加引用视图的外键约束

2022-08-03 00:00:00 constraints foreign-keys mysql view

当被引用的表实际上是一个视图时,我是否可以在MySQL中添加外键约束?

基于以下原因,我可能会觉得奇怪,表和视图被视为不同的格式https://stackoverflow.com/a/31183407/1342636

在我看来这是不允许的,但我还没有看到任何实际声明它是不允许的。


解决方案

要将字段定义为foreign key,引用的父字段必须定义有索引。

根据foreign key constraints上的文档:

引用PARENT_Tbl_NAME(INDEX_COL_NAME,...)

由于视图是虚拟的表,所以它的所有字段也都是虚拟的。
虚拟字段不支持定义index

根据Restrictions on Views上的文档:

无法在视图上创建索引。

,因此您不能使用虚表(即view)作为引用的父表(不支持索引)来定义和映射外键以创建子表。

示例:

相关文章