V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
tctc4869
V2EX  ›  程序员

有一个数据类型的 Model,其中有子项 C 和 B, Model 的实例要么有 C 无 B,要么有 B 无 C。怎么设计合适的数据表?

  •  
  •   tctc4869 · 2020-07-02 09:39:45 +08:00 · 1009 次点击
    这是一个创建于 1631 天前的主题,其中的信息可能已经有所发展或是发生改变。

    有一个数据类型的 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 字段内容。这个合适么?有更好的设计思路么?

    netnr
        1
    netnr  
       2020-07-02 10:01:09 +08:00
    提取 表 C 、B 共同的字段为 D 表,BC 关联 D 表,AB 表关联
    当然 AB 表关联要能满足你需要的数据
    netnr
        2
    netnr  
       2020-07-02 10:01:51 +08:00
    纠正:

    提取 表 C 、B 共同的字段为 D 表,BC 关联 D 表,AD 表关联
    当然 AD 表关联要能满足你需要的数据
    jiyingze
        3
    jiyingze  
       2020-07-02 10:18:08 +08:00
    bc 合并为一张表,字段是两中类型的并集,加个字段标识类型
    tctc4869
        4
    tctc4869  
    OP
       2020-07-02 10:21:35 +08:00
    @jiyingze b 和 c 是独立的。就像 lbs 和 gps,虽然都有定位信息,但是相两者,也有其他的不同类型的数据。结构上是不一样的
    Uyuhz
        5
    Uyuhz  
       2020-07-02 11:01:25 +08:00
    @tctc4869 之前遇到需要类似需求,客户端上传数据包,内容一种是 GPS 定位一种是基站定位,直接用了 MongoDB,舒服
    tctc4869
        6
    tctc4869  
    OP
       2020-07-02 11:06:09 +08:00
    @Uyuhz 你是怎么存的?存一起么?然后用个 bool 类型标识?
    Uyuhz
        7
    Uyuhz  
       2020-07-02 11:19:45 +08:00
    @tctc4869 我用的 MongoDB,不用管类型、字段,两种定位数据直接插入同一个表
    aguesuka
        8
    aguesuka  
       2020-07-02 12:11:05 +08:00 via Android
    a inner join b on id and type union a join c on id and type
    otakustay
        9
    otakustay  
       2020-07-02 13:22:55 +08:00
    现实里应该都是合成一张表的,表里有 B+C 的所有字段,甚至可能和 A 也合一张表,一行要么空前一半字段,要么空后一半字段,空着就空着
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4091 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 05:22 · PVG 13:22 · LAX 21:22 · JFK 00:22
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.