MySQL添加引用视图的外键约束
当被引用的表实际上是一个视图时,我是否可以在MySQL中添加外键约束?
基于以下原因,我可能会觉得奇怪,表和视图被视为不同的格式https://stackoverflow.com/a/31183407/1342636
在我看来这是不允许的,但我还没有看到任何实际声明它是不允许的。
解决方案
要将字段定义为foreign key
,引用的父字段必须定义有索引。
根据foreign key
constraints上的文档:
引用PARENT_Tbl_NAME(INDEX_COL_NAME,...)
由于视图是虚拟的表,所以它的所有字段也都是虚拟的。
虚拟字段不支持定义index
。
根据Restrictions on Views
上的文档:
无法在视图上创建索引。
,因此您不能使用虚表(即view)作为引用的父表(不支持索引)来定义和映射外键以创建子表。
示例:
相关文章