评论功能里数据库的设计

简介: 【4月更文挑战第2天】本文探讨了评论系统的树形结构设计,提出了四种方法:邻接表、分段式path、Nested Set和Closure Table。针对评论业务功能,如加载评论页和查看回复,优先考虑邻接表和分段式path。采用邻接表思路,设计了评论表结构,包括Uid、Biz、BizID、RootID、PID、Content、索引和级联删除规则。同时提到了索引设计,如Uid、Biz+BizID、PID和Ctime/Utime,以优化查询性能。

回复评论的层级:

树形结构,资源 -> 一级评论 -> 二级评论 -> 三级评论

树形结构设计的几种思路

  1. 邻接表:有一个parent_id的列,指向父节点,值一般都是节点的主键。根节点的parent_id可以用NULL表示,也可以用非法值(比如-1表示)
  2. 分段式path:有一列维持根节点到当前节点的路径。比如path的值式a/b/c,那么根据路径的定义分别由两种解释,如果路径包含当前节点,当前节点就是c,父节点是b,根节点是a;如果路径不包含当前节点,c是当前节点的父节点。
  3. Nested Set:需要维持住两个额外的列nsleft和nsright,其中nsleft小于所有子节点的nsleft,nsright大于所有子节点的nsright,类似于二叉搜索树的概念,两个列的取值,也相当于是dfs的顺序
  4. Closure Table:用一张额外的表维护各个节点之间的关系,比如ancestor代表的是祖先节点,descendant表示后继节点。一个节点和后继节点会有一行数据,一个节点和祖先节点也会有一行数据,所以会产生大量的数据

评论的业务功能

  1. 加载某资源的第一页评论
  2. 加载某资源的第一页评论的直接评论,分批加载
  3. 查看某评论的更多评论

其中功能1是根据业务类型和业务id来查询,功能2-3都是查询某个节点的子节点。所以优先考虑思路1邻接表和思路2分段式path。思路2分段式path里,查询子节点是使用Like来查询的,性能较差。先考虑思路1邻接表的实现

根据思路1邻接表的写法,结合具体的业务,可以得到表结构设计如下:

  • Uid:表示发表评论的用户的唯一标识
  • Biz:表示该评论的业务场景,例如视频、评论、用户
  • BizID:表示评论的资源的唯一表示
  • RootID:根ID
  • PID:父评论的ID
  • ParentComment:外键约束,为了级联删除。指定外键使用的是PID,关联外键的字段是ID,OnDelete:CASCADE设置删除策略采用级联删除
type Comment struct {
   
    Id int64 `gorm:"autoIncrement,primaryKey"`
    Uid int64
    Biz     string `gorm:"index:biz_type_id"`
    BizID   int64  `gorm:"index:biz_type_id"`
    Content string
    RootID sql.NullInt64 `gorm:"column:root_id;index"`
    PID sql.NullInt64 `gorm:"column:pid;index"`
    ParentComment *Comment `gorm:"ForeignKey:PID;AssociationForeignKey:ID;constraint:OnDelete:CASCADE"`
    Ctime int64
    Utime int64
}

索引设计如下:

  • Uid:可选,比如如果需要查询某个用户发表过的所有评论,就需要该索引
  • Biz+BizID:解决查找某个资源的评论的场景
  • PID:为了查找子节点,某个评论下面的所有一级回复
  • Ctime/Utime:看是否需要排序
目录
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
阿里云RDS云数据库全解析:产品功能、收费标准与活动参考
与云服务器ECS一样,关系型数据库RDS也是很多用户上云必买的热门云产品之一,阿里云的云数据库RDS主要包含RDS MySQL、RDS SQL Server、RDS PostgreSQL、RDS MariaDB等几个关系型数据库,并且提供了容灾、备份、恢复、监控、迁移等方面的全套解决方案,帮助您解决数据库运维的烦恼。本文为大家介绍阿里云的云数据库 RDS主要产品及计费方式、收费标准以及活动等相关情况,以供参考。
|
4月前
|
SQL 存储 关系型数据库
MySQL功能模块探秘:数据库世界的奇妙之旅
]带你轻松愉快地探索MySQL 8.4.5的核心功能模块,从SQL引擎到存储引擎,从复制机制到插件系统,让你在欢声笑语中掌握数据库的精髓!
171 26
|
9月前
|
存储 NoSQL 关系型数据库
PolarDB开源数据库进阶课17 集成数据湖功能
本文介绍了如何在PolarDB数据库中接入pg_duckdb、pg_mooncake插件以支持数据湖功能, 可以读写对象存储的远程数据, 支持csv, parquet等格式, 支持delta等框架, 并显著提升OLAP性能。
586 2
|
6月前
|
存储 缓存 自然语言处理
评论功能开发全解析:从数据库设计到多语言实现-优雅草卓伊凡
评论功能开发全解析:从数据库设计到多语言实现-优雅草卓伊凡
173 8
评论功能开发全解析:从数据库设计到多语言实现-优雅草卓伊凡
|
8月前
|
SQL Linux 数据库
【YashanDB知识库】崖山数据库Outline功能验证
本文来自YashanDB官网,主要测试了数据库优化器在不同场景下优先使用outline计划的功能。测试环境包括相同版本新增数据、绑定参数执行、单机主备架构以及数据库版本升级等场景。通过创建表、插入数据、收集统计信息和创建outline等步骤,验证了在各种情况下优化器均能优先采用存储的outline计划。测试结果表明,即使统计信息失效或数据库版本升级,outline功能依然稳定有效,确保查询计划的一致性和性能优化。详情可见[原文链接](https://www.yashandb.com/newsinfo/7488286.html?templateId=1718516)。
【YashanDB知识库】崖山数据库Outline功能验证
|
8月前
|
NoSQL 关系型数据库 MongoDB
Apifox与Apipost数据库连接功能详细对比,让接口管理更高效!
在现代软件开发中,数据库是应用运行的核心组件,接口管理工具则是连接和调试数据库的重要桥梁。本文对比了 Apifox 和 Apipost 两款工具的数据库连接功能。Apipost 支持全面的关系型与非关系型数据库(如 MySQL、Redis、MongoDB),功能强大且免费,适合复杂项目;而 Apifox 在关系型数据库支持上表现良好,但非关系型数据库(尤其是 Redis)功能有限且收费,更适合中小项目以关系型数据库为主的需求。根据项目需求选择合适的工具,可显著提升开发效率和稳定性。
|
8月前
|
数据库连接 PHP 数据库
【YashanDB知识库】PHP使用ODBC使用数据库绑定参数功能异常
【YashanDB知识库】PHP使用ODBC使用数据库绑定参数功能异常
|
8月前
|
PHP 数据库
【YashanDB知识库】PHP使用OCI接口使用数据库绑定参数功能异常
【YashanDB知识库】PHP使用OCI接口使用数据库绑定参数功能异常
|
8月前
|
存储 NoSQL 关系型数据库
Apifox与Apipost数据库连接功能详细对比,让接口管理更高效!
Apipost 更加全面:无论是关系型还是非关系型数据库,它都为开发者提供了一站式解决方案,非常适合数据库架构复杂的大型项目。相对来说,Apifox偏重关系型分析和管理:若项目主要需求在于管理关系型数据库,而对非关系型的依赖较小,Apifox倒是可以应付。
219 2
|
8月前
|
SQL 关系型数据库 数据库连接

热门文章

最新文章