有一个数据类型的 Model,称呼为 A,A 其中有子项 C 和 B,C 和 B 的数据 Model 结构不一样,但 C 和 B 的其中有共同的名称和共同的数据类型的字段。a 的实例中,要么有 C 无 B,要么有 B 无 C 。B 和 C 都和 A 是一对一关系。
我想设计一个数据查询,查询 A 的数据集,并得到子项 C 或子项 B 的其中指定的共同名称的字段内容
比如该设想,
C 和 B 的数据结构不一样,但都有 TestData 名称的字符串类型字段。如果转成数据表,我目前的想法就是 A 表,B 表,C 表三个表。
但是基于“要么有 C 无 B,要么有 B 无 C”这种情况,要怎么设计关联?怎么设计一个“查询 A 的数据集,并得到子项 C 或子项 B 的其中指定的共同名称的字段内容”的查询语句?
我目前考虑是在 A 表中,用两个字段,叫 B_id 和 C_id,存 B 表和 C 表的一行的主键 id,A 表的一行中,要么 B_id 有内容,C_id 是 Null,要么 C_id 有内容,B_id 是 Null 。查询时通过 A left join B on A.B_id =B.id A left join C on A.C_id =C.id 查询,然后通过 case 语句调整结果集,根据 B_id 或 C_id 是否为 Null 得到 B 或 C 的 TestData 字段内容。这个合适么?有更好的设计思路么?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.