• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

文章评论嵌套显示mysql表结构如何设计(形式如网易新闻评论)

php 搞代码 3年前 (2022-01-22) 35次浏览 已收录 0个评论
文章目录[隐藏]

现在有一张post表 (结构不能改变)
tid 主题pid
pid 回复id

现在新增了评论嵌套显示功能,即tid=1
a评论了一条 pid为1
b回复了a的评论 pid为2
c回复了b的评论 pid为3
d回复了a pid为4

显示为
1楼 pid1
2楼 pid1,pid2
3楼 pid1,pid2,pid3
4楼 pid1,pid4
即每一个对他人的回复都需要引用之前所有的回复。
(形式跟网易新闻的评论一样)
我目前想到一种结构就是post_conversation pid ,to_pid
这样 2楼回复就插入 2,1

<code> 3楼回复就插入两条     3,1                     3,2 4楼回复就插入         4,1          </code>

如果有一个99楼的对话 就得插入98条数据

<code>这样有个好处就是可以很方便取出任意一个pid的评论情况select topid from post_conversation  where pid = 'xxx' order by pid ;但是会造成多的重复数据  一个99楼对话得插入1+2+3+。。。+99条</code>

如果这么设计 post_conversation
pid,parent_pid(被回复的pid)
数据量是小了,(每次回复只插入一条);
但是查询每一个pid的所有对话,很麻烦(我想到的是递归查询数据库);

<code>select parent_pid from post_conversation  where pid = 'xxx'    select parent_pid from post_conversation  where pid = 'parent_pid '        ...        一直到parent_pid 为0为止,查询出所有的对话pid</code>

请问大家有没有好的建议

回复内容:

现在有一张post表 (结构不能改变)
tid 主题pid
pid 回复id

现在新增了评论嵌套显示功能,即tid=1
a评论了一条 pid为1
b回复了a的评论 pid为2
c回复了b的评论 pid为3
d回复了a pid为4

显示为
1楼 pid1
2楼 pid1,pid2
3楼 pid1,pid2,pid3
4楼 pid1,pid4
即每一个对他人的回复都需要引用之前所有的回复。
(形式跟网易新闻的评论一样)
我目前想到一种结构就是post_conversation pid ,to_pid
这样 2楼回复就插入 2,1

<code> 3楼回复就插入两条     3,1                     3,2 4楼回复就插入         4,1          </code>

如果有一个99楼的对话 就得插入98条数据

<code>这样有个好处就是可以很方便取出任意一个pid的评论情况select topid from post_conversation  where pid = 'xxx' order by pid ;但是会造成多的重复数据  一个99楼对话得插入1+2+3+。。。+99条</code>

如果这么设计 本@文来源gao($daima.com搞@代@#码(网5搞gaodaima代码 post_conversation
pid,parent_pid(被回复的pid)
数据量是小了,(每次回复只插入一条);
但是查询每一个pid的所有对话,很麻烦(我想到的是递归查询数据库);

<code>select parent_pid from post_conversation  where pid = 'xxx'    select parent_pid from post_conversation  where pid = 'parent_pid '        ...        一直到parent_pid 为0为止,查询出所有的对话pid</code>

请问大家有没有好的建议

谢邀
曾经我这边也是用最原始那种递归查询的方法来实现(菜单,评论)无限嵌套。后来在 Laravel-China 社区看到管理员发的一篇文章,文章地址https://laravel-china.org/topics/2124,使用 预排序遍历树算法(Nested set model) 实现无限树状层级模型(标签系统,菜单系统,评论系统等)。题主可以参考下。

“引用评论”实现代价比较大,冗余比较多,可以考虑用”回复评论”来替代:
一篇文章对应多条评论,一条评论对应多条回复.
问答社区segmentfault.com和腾讯新闻等用的都是”回复评论”.
就拿segmentfault来说:
提问者(楼主)发了一个问题,这个问题有多个回答(层主),在数据库是一对多的关系.
每个回答又可以有多个回复,也是一对多的关系.

<code>question(id,            user_id,content)answer  (id,question_id,user_id,content)reply   (id,answer_id,  user_id,content)</code>

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:文章评论嵌套显示mysql表结构如何设计(形式如网易新闻评论)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址