OlymHuang 2014-12-09 02:50 采纳率: 100%
浏览 2910
已采纳

针对复杂的多级栏目该如何设计数据库表结构?

比如可能存在如下几种情况:
主栏目1-->子栏目2-->子栏目3-->内容列表-->内容
主栏目2-->子栏目2-->内容列表-->内容
主栏目3-->内容列表-->内容

如果说为了开发和后期维护的方便,以及后期新的内容添加或删除方便,栏目表应该如何设计比较符合规范?
比如栏目按照一定规则拼接放到一个字段里:
主栏目1|子栏目11|子栏目111
主栏目2|子栏目21|子栏目212|子栏目2121
或者每个栏目另加个字段,存放父栏目的code?

或者有其它更好的方式或者有一定的设计规范?
我对数据库设计不太熟,望指点!

  • 写回答

5条回答 默认 最新

  • modii 2014-12-10 02:52
    关注

    作为内容表来说,这样的结构就够了:内容id,挂载栏目id,内容标题,内容。。。

    现在来说比较复杂的递归表,这里最好分析下你的数据库。
    最简单的设计方案是 id+parentId的设计,这是最经典的递归设计方案,没有层级限制,没有每级的栏目个数限制。而且oracle有递归函数支持。

    现在来说一种取巧的设计方式,类似于你上面写的 111、212这样的设计。这种设计在检索上是有利的,缺点是有限制,更具字段的长度,有最多级次限制,而且每级也有个数限制(当然,可以通过设计让这个限制不存在)。

    简单来说,如果级次表数据量不上GB、条数不到千万。id + parentId是最合适也是最灵活的设计。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵