当前位置: 首页 > 面试题库 >

Redis GET与SQL SELECT

松英叡
2023-03-14
问题内容

我对NoSQL还是很陌生,但是我一直很喜欢它的想法。我看了看Redis,并提出了一些有关存储和接收多个最佳方法的问题hashes

假设以下情况:

Store a list of objects (redis 'Hashes') and select them by their timestamp.

要将其归档SQL,需要一个表和两个简单​​查询(INSERT&SELECT)。

尝试在中执行此操作Redis,最终创建了以下结构:

  1. object:$id (散列) 含有object
  2. index:timestamp:$id (排序集) score 等于timestampvalue包括id

虽然我可以承担两个键而不是一个表( SQL )的额外维护工作,但我对 选择多个对象 的过程感到好奇:

ZRANGEBYSCORE index:timestamp:$id timestampStart timestampEnd

这会返回arraytimestampStart和之间创建的所有ID中的一个timestampEnd。为了获取对象本身,我通过以下方法请求每个对象:

GET object:$id
  • 这是正确的做法吗?
  • 与SQL数据库相比:由于GETs的数量过多,它是否仍然明显更快或更慢?

问题答案:

一个ZRANGEBYSCORE成本O(log(N) + M),其中N=|items in your set|M=|items you're selecting|。因此,先进行ZRANGEBYSCORE然后再进行M次GET运算仅O(long(N)+M+M)=
=,O(log(N)+M)并且最多慢两倍。来回移动网络可能会造成很大的影响,但是由于每个获取操作都是独立的操作,因此可以通过管道进行传输。您还可以将整个内容放入Lua脚本中,并且只进行一次来回移动,这将是最佳选择。我要说的是99%的确定性比在SQL中做同样的事情要快。

另外,如果这对您来说是非常频繁的操作,则可以通过将整个对象存储在排序集中而不是仅存储id中来提高处理速度。你必须key = object encoded as jsonscore = timestamp。这样就可以节省您O(M)的操作时间,而无需执行任何操作GET

这是否是一种好的处理方式,实际上取决于您的用例。您真正需要多少速度?传统数据库的其他功能对您来说有多重要?请记住,与传统数据库相比,Redis不仅仅是客户端可访问的数据结构,而且它必须将所有内容存储在RAM中。要知道这是否适合您,我们需要更多信息。



 类似资料:
  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 我正试图掌握mysqli对象及其工作方式。我使用上面的查询查找数据库的表名,并将它们插入select下拉列表。当我使用类似的代码填充另一个select下拉列表时,我使用在while循环运行时获取结果。然后我的select语句是当我使用上面的select语句时,我需要使用索引0而不是“table\u name”。为什么呢?当我在PHP MyAdmin中运行上面的select语句时,我得到了一个行名为

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认

  • 问题内容: 我今天刚刚与一些同事讨论了python的db-api fetchone vs fetchmany vs fetchall。 我确定每个应用程序的用例都取决于我正在使用的db-api的实现,但是总的来说,fetchone,fetchmany,fetchall的用例是什么? 换句话说,以下等效项是什么?还是其中之一比其他人更受青睐?如果是这样,在哪些情况下? 问题答案: 我认为这确实取决于

  • 问题内容: 即时创建元素并能够移动元素的最佳方法是什么?例如,假设我要创建一个矩形,圆形和多边形,然后选择这些对象并四处移动。 我了解HTML5提供了三个使之成为可能的元素:svg,canvas和div。对于我想做什么,这些元素中的哪一个将提供最佳性能? 为了比较这些方法,我正在考虑创建三个视觉上相同的网页,每个网页中都有页眉,页脚,小部件和文本内容。第一页中的小部件将完全使用元素创建,第二页中的