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

求助! Mongodb 用户自定义导航表结构该如何设计?

  •  
  •   geekape · 2022-09-19 16:37:51 +08:00 · 1139 次点击
    这是一个创建于 832 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我的一个 nav 表,结构是这样的:

    {
        categoryId: String,
        name: String,
        href: String,
        desc: String,
        logo: String,
        authorName: String,
        authorUrl: String,
        auditTime: Date,
        createTime: Date,
        status: {
          type: Number,
          default: 0,
        },
      	...
      }
    

    我想实现的功能是,用户可以添加和修改导航,但是不会影响主导航的显示效果。

    你会怎么设计表结构?是再新建一个用户导航表,还是弄一个关联用户 id 和导航 id 的表,如果是怎么查询呢?

    7 条回复    2022-09-19 19:31:20 +08:00
    Jinnyu
        1
    Jinnyu  
       2022-09-19 16:57:11 +08:00
    导航内容表
    用户导航表(用户 id, 导航 id, 显示顺序, 其他属性...)
    默认导航数据的显示顺序从 1 开始, 用户导航从 100 开始
    然后用用户 id 去查询, 排序
    signalas1
        2
    signalas1  
       2022-09-19 17:05:32 +08:00
    默认一个初始化导航列表, 然后每个用户初始化之后自己有一份完整导航列表的拷贝,不关联。
    geekape
        3
    geekape  
    OP
       2022-09-19 17:11:18 +08:00
    @Jinnyu 这样子相当于用户导航和导航表相同重复的结构了吧
    geekape
        4
    geekape  
    OP
       2022-09-19 17:15:05 +08:00
    @signalas1 你是说单独一个用户导航表,每个用户初始化一份导航?如果有 1 万个导航,那用户不得也 copy1 万个重复的结构吗?
    signalas1
        5
    signalas1  
       2022-09-19 17:45:02 +08:00
    @geekape Mongodb entry level 的建议,之前想用 Mongodb 表达 many-to-many ,搜到的解答都是说让冗余。
    dreasky
        6
    dreasky  
       2022-09-19 17:50:59 +08:00
    mongodb 尽量不关联 每个用户一份
    Jinnyu
        7
    Jinnyu  
       2022-09-19 19:31:20 +08:00
    @geekape #3
    导航内容不是你们规定好的嘛 只不过每个人的顺序不同
    你们只需要维护导航内容就可以了呀
    剩下的用用户导航表就够了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2806 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 14:45 · PVG 22:45 · LAX 06:45 · JFK 09:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.