我的一个 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 的表,如果是怎么查询呢?
![]() | 1 Jinnyu 2022-09-19 16:57:11 +08:00 导航内容表 用户导航表(用户 id, 导航 id, 显示顺序, 其他属性...) 默认导航数据的显示顺序从 1 开始, 用户导航从 100 开始 然后用用户 id 去查询, 排序 |
![]() | 2 signalas1 2022-09-19 17:05:32 +08:00 默认一个初始化导航列表, 然后每个用户初始化之后自己有一份完整导航列表的拷贝,不关联。 |
![]() | 4 geekape OP @signalas1 你是说单独一个用户导航表,每个用户初始化一份导航?如果有 1 万个导航,那用户不得也 copy1 万个重复的结构吗? |
![]() | 5 signalas1 2022-09-19 17:45:02 +08:00 @geekape Mongodb entry level 的建议,之前想用 Mongodb 表达 many-to-many ,搜到的解答都是说让冗余。 |
![]() | 6 dreasky 2022-09-19 17:50:59 +08:00 mongodb 尽量不关联 每个用户一份 |