- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我一直在努力寻找嵌套评论的数据结构(只有一层嵌套,例如 facebook)
为了实现评论的非嵌套“提要”,我一直在使用排序集来跟踪评论,使用分数作为时间戳,使用成员作为包含呈现所需的所有信息的 json 编码属性集评论。
所以添加评论可能是这样的:
zadd 'users:1:comments', 123456789, {body : 'hello'}
检索它就这么简单:
zrevrange 'users:1:comments', 0, 20
为了支持嵌套评论,我尝试以某种方式对此进行扩展我想出了两种不同的方法,但每种方法都有一个问题:
1)
将comment_id添加到属性列表中,其中comment_id指向父评论
zadd 'users:1:comments', 123456789, {id : 1, body : 'hello'}
zadd 'comments:1:comments', 123456789, {id : 2, body : 'nested hello', comment_id : 123 }
看起来像这样:
-hello
-nested hello
这种方法的问题在于分页。如果,比如说,一个评论有 20 个嵌套评论,而我只显示前 10 个评论,那么嵌套树将被切断(父评论 + 9 个嵌套评论将被检索)
2)
将嵌套的评论放入自己的提要中:
This is a parent comment
zadd 'users:1:comments', 123456789, {id: 1, body : 'hello'}
this is a nested comment
zadd 'comments:1:comments' 123456789, {id: 2, body : 'nested hello'}
但是,这会在尝试显示用户的提要时导致 N+1 个 redis 查询:
zrevrange 'users:1:comments', 0, 20
zrevrange 'comments:1:comments', 0, 20
zrevrange 'comments:2:comments', 0, 20
etc...
...更不用说嵌套的评论可能不应该选择一个范围。
理想情况下,我希望它能与单个 Redis 查询一起使用,但我不确定如何构建我的数据以便实现这一点。
想法?
最佳答案
我能想出的唯一方法是使用 Lists 来生成单个 Redis 查询。 .
添加父项时,您可以简单地将其LPUSH
到列表的顶部(左侧)。添加子评论时,您可以使用类似 LINSERT 'user:1:comments' AFTER parent-comment-data child-comment-data
。
这会导致redis 搜索父评论数据并将子数据紧跟其后。这是一个 O(N) 操作,从上(左)到下(右)完成,因此父级列表越往下,此操作将花费的时间越长,因此对于极长列表此可能会出现问题(但如果您将列表/线程大小保持在 4 或 5 位数范围内应该没问题)。
然后,一个简单的 LRANGE
可以为您获取最新的评论,包括 parent 和 child ,限制为任意数量。
您可以使用排序集中的分值做类似的事情,给 child 一个比 parent 低的分数。但是,这可能会使插入变得非常复杂,因为您可能会用完两个父评论之间的可用分数,这意味着您必须运行一个操作来为许多(甚至大多数)评论重新分配分数。如果这种情况发生在每个插入物上,您的插入物可能(不必要地)昂贵。
关于comments - 如何在 Redis 中构造 1 级嵌套注释?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7638209/
有没有办法在 Brainfuck 中做包含句点('.')的评论? 我知道我基本上可以使用不是命令之一的每个字符,它会被忽略,但我想在文件顶部的注释中放置一个版本号,其中包含一个句点。 最佳答案 您可以
我不明白以下代码的 % comment.length 位: comment.charAt(i % comment.length()) 括号之间的部分是否会转换为整数,其值表示与评论长度相关的i? 例如
我终于找到了我的 PHP 脚本无法运行的原因。这是因为 MySQL "--comment"而不是 "-- comment"。我最近开始使用 PHP,直到那时,我一直使用“--comment”。现在,我
是否可以在项目中搜索用户在 checkin 文件后添加的评论? (手动可以通过选择一个文件,右键单击 --> 显示历史记录 --> 选择版本 --> 详细信息,在评论 Pane 中查看)。 是否可以自
我不完全确定这是否不是插件,但是在 .js 文件中开始一行注释之后,例如,当我按下回车键时,下一行也以“//”开头。这有点烦人。有没有简单的方法可以删除它? 最佳答案 在“首选项 -> 包设置 ->
我在网上搜索,没有找到解释这个评论 block 用法的结果。因此,我希望有人能向我解释这种评论风格背后的原因。 /// Text goes here. 最佳答案 它们是 XML 文档注释。 http
这有充分的理由吗?这是一个蹩脚的问题,但我只是想知道是否有原因。 最佳答案 因为 specification允许/**/但不允许//:) 不过,严重的是,CSS 像对待所有其他空格一样对待换行符,并且
我有一个评论模型,我看过使用 @comment, :comment, comment 来引用 MVC 中的对象的示例。我怎么知道哪个是哪个?有区别吗? 最佳答案 @comment指 Rails Con
我有一些使用 Drupal 实现的网站。然而,尽管 Drupal 很酷,但我从未对它的编码感到满意,主要是因为它是在 PHP 中的,而且我想使用 python。我曾与 Django 调情,但我最近才发
似乎我仍然没有完全转变为 mac 用户(来自 Windows),再次遇到键盘快捷键问题: 在 phpstorm 中,下拉菜单中显示了以下“带有行注释的注释”的快捷方式: 现在,问题是,我的键盘上没有“
我正在按照 here 所述使用 fb:comments| . 评论工作正常,但我找不到在添加新评论时收到通知的方法。有没有办法轻松找到新评论(无需每次都访问我的 3000 篇文章)? 我知道 FB 对
我正在尝试创建一个功能,用户可以在其中使用 Ajax 创建对文章的评论。但是,我不明白为什么只有存在一个评论才能通过 ajax 成功呈现评论。评论提交到数据库,没有任何回滚。 如果我重新加载页面并创建
我正在使用 mongodb native 驱动器来获取查询结果的游标。 我正在使用一个“评论”字段,它基本上是一个字符串,下面是我正在使用的代码片段 let leve1_n = 'labreports
如果我将此URL放入浏览器中:。Https://www.facebook.com/plugins/comments.php?api_key=MYAPID。它会显示注释框,但不会显示任何评论。谁能告诉我
我想显示每个项目的评论数量和最后评论的日期。 SELECT item.*, count(comments.itemid) AS commentcount, comments.created A
这个问题在这里已经有了答案: What is the second parameter of NSLocalizedString()? (5 个答案) 关闭 6 年前。 我搜索并阅读了 NSLoca
我希望我的 Wordpress 博客中的字幕能够计算我的帖子在 Facebook 上的评论数。插入Facebook的代码后 ID); ?>"> comments 我意识到当我只有 1
我在我的项目中收到以下 TsLint 消息: TsLint: comment must start with lowercase letter 这背后有什么依据吗?我同意我在 TsLint 中遇到的大
我正在使用以下代码完成教程: New Comment @comment = Comment.new, :locals => { :button_name => "Create" } %>
环境 适用于macOS的Visual Studio代码1.18.0。 主题hedinne.popping-and-locking-vscode,由 hedinne 组成。 问题 当我覆盖/*> edi
我是一名优秀的程序员,十分优秀!