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

2022-09-19 16:37:51 +08:00
 geekape

我的一个 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 的表,如果是怎么查询呢?

1107 次点击
所在节点    程序员
7 条回复
Jinnyu
2022-09-19 16:57:11 +08:00
导航内容表
用户导航表(用户 id, 导航 id, 显示顺序, 其他属性...)
默认导航数据的显示顺序从 1 开始, 用户导航从 100 开始
然后用用户 id 去查询, 排序
signalas1
2022-09-19 17:05:32 +08:00
默认一个初始化导航列表, 然后每个用户初始化之后自己有一份完整导航列表的拷贝,不关联。
geekape
2022-09-19 17:11:18 +08:00
@Jinnyu 这样子相当于用户导航和导航表相同重复的结构了吧
geekape
2022-09-19 17:15:05 +08:00
@signalas1 你是说单独一个用户导航表,每个用户初始化一份导航?如果有 1 万个导航,那用户不得也 copy1 万个重复的结构吗?
signalas1
2022-09-19 17:45:02 +08:00
@geekape Mongodb entry level 的建议,之前想用 Mongodb 表达 many-to-many ,搜到的解答都是说让冗余。
dreasky
2022-09-19 17:50:59 +08:00
mongodb 尽量不关联 每个用户一份
Jinnyu
2022-09-19 19:31:20 +08:00
@geekape #3
导航内容不是你们规定好的嘛 只不过每个人的顺序不同
你们只需要维护导航内容就可以了呀
剩下的用用户导航表就够了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/881311

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX