AWS Athena 上的 OFFSET

2023-11-25

我想在 AWS Athena 上运行查询LIMIT and an OFFSET条款。我认为前者受到支持,而后者不是。有没有办法使用其他方法来模拟此功能?


Using OFFSET分页效率非常低,特别是对于像 Presto 这样经常需要执行全表或分区扫描的分析数据库。此外,查询之间的结果不一定一致,因此在页面之间导航时可能会出现重复或丢失的结果。

In an OLTP对于 MySQL 或 PostgreSQL 等数据库,最好对索引使用范围查询,这样您可以跟踪上一页上看到的最后一个值。

In an OLAP像Presto这样的数据库,最好缓存结果集并使用缓存的数据进行分页。您不希望每次用户单击转到不同页面时都对数十亿或数万亿行运行昂贵的查询。

有关问题和索引方法的详细说明,请参阅这些文章:

  • http://use-the-index-luke.com/no-offset
  • http://use-the-index-luke.com/sql/partial-results/fetch-next-page
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

AWS Athena 上的 OFFSET 的相关文章

随机推荐

  • mongodb是否具有关系型数据库中的trigger、procedure等属性?

    正如标题所示 包括 Map Reduce 框架 如果我想在插入记录之前触发一个事件来运行一致性检查或安全操作 我该如何使用 MongoDB 来做到这一点 MongoDB 不支持触 发器 但人们已经围绕它们创建了解决方案 主要使用 oplog
  • Java中超类引用无法调用子类方法

    我对Java的多态性有一个基本的怀疑 我已将下面的代码写入一个名为 AnimalTestDrive java 的文件中 根据我的说法 下面的代码应该特别适用于粗体行 但不幸的是它不是 你能解释一下为什么吗 我给出了以下错误 class Do
  • 在 Chart.js 段中嵌入唯一标识符?

    我想通过允许用户双击切片进行向下钻取来使饼图具有交互性 我相信做到这一点的方法是在画布上创建一个 onclick 处理程序 并使用getSegmentsAtEvent 以确定单击了哪个切片 调用返回的段数据getSegmentsAtEven
  • 缓慢的“属性获取”和“函数”过程

    我遇到了一个令人讨厌的 VBA 错误 它使得Property Get过程调用真的很慢 这很可能是由于最近的 Office 更新 我有 Office365 造成的 它仅影响 32 位 CPU 上的 Excel The bug 考虑一个名为Cl
  • 变更数据捕获或变更跟踪 - 与传统审计跟踪表相同吗?

    在我深入研究 Microsoft 文档的深渊之前 我想知道有变更数据捕获和变更跟踪经验的人是否知道其中之一或两者是否可以用来取代传统的 审计追踪表副本 真实 table 原始表的所有字段 加上日期 时间 用户 ID 和 DML 动作字段 插
  • 您能推荐 PHP 性能分析工具吗? [关闭]

    就目前情况而言 这个问题不太适合我们的问答形式 我们希望答案得到事实 参考资料或专业知识的支持 但这个问题可能会引发辩论 争论 民意调查或扩展讨论 如果您觉得这个问题可以改进并可能重新开放 访问帮助中心以获得指导 谁能推荐一些有用的 PHP
  • 非静态成员函数的 decltype 格式是否错误?

    我不确定是否完全理解 dcl type 4 3 对于一个表达式e 表示的类型decltype e 定义如下 4 3 否则 如果e是不带括号的 id 表达式或不带括号的类成员访问 decltype e 是命名实体的类型e 如果没有这样的实体
  • 如何在 Java 中使用正则表达式查找重复字符?

    谁能给我一个 Java 正则表达式来识别字符串中的重复字符 我只寻找立即重复的字符 它们可以是字母或数字 Example abcccde abcde Try w 1 The w匹配任何单词字符 字母 数字或下划线 并且 1 匹配第一组括号中
  • Javascript:未定义为函数参数

    On this page 它显示了一些示例代码 包含以下行 var Subject function window undefined 是什么undefined作为函数参数 这用于防止覆盖值undefined在非严格模式下 在非严格模式下
  • SendMessage,什么时候使用KEYDOWN,SYSKEYDOWN等?

    我正在编写一个应用程序 使用以下命令将击键发送到另一个应用程序SendMessage DllImport user32 dll public static extern int SendMessage IntPtr hWnd int Msg
  • C++11 lambda 到函数指针

    我开始使用 C 11 lambda 开发应用程序 并且需要将某些类型转换为函数指针 这在 GCC 4 6 0 中完美运行 void test puts Test test 我的问题是当我需要在 lambda 中使用函数或方法局部变量时 co
  • PrintWriter 和 DataOutputStream 有什么区别?

    我正在开发一个 Android 聊天室应用程序 我阅读了不同的教程 有些使用PrintWriter发送数据 有些使用DataOutputStream 这两者有什么区别 哪一个更适合聊天应用程序 来自java文档 A 数据输出流允许应用程序以
  • Django 中的 related_name 和 related_query_name 是什么?

    我对 django 框架中的代码有一个问题related name 和 related query name在 Django 中 请django专家解释一下django中的 related name 代码如下 相关名称 相关名称 Djang
  • 适合多个客户的 Android 构建配置

    我有一个 Android 应用程序需要交付给多个客户 对于每个客户 我都有不同的图形和配置 XML 文件 其中指定了功能和 URL 在构建时 我们应该能够指定应为其构建应用程序的客户 然后 应将适合指定客户端的资源 例如图像和运行时配置 内
  • 仅当字段不为 Null 时才验证

    I use JSR303 Spring Validation我有以下内容 Digits fraction 0 integer 15 private String tpMobile 验证说Must be number between 10 1
  • 如何在 Java 中解密 sha1 加密的字符串

    是否有可能解密一些之前用 Java 中的 SHA 1 算法加密的字符串 SHA1 是加密哈希函数 重点是您无法撤消它 如果可以反转哈希值 找到给定哈希值的输入 那么它就没有用处 如果您需要加密某些内容然后解密它 您应该使用加密功能 like
  • 如何将参数 n 传递给 printf("%nd", some_int);

    我们都知道在基于 C 的语言中 printf 11d some int 意味着在 11 个字符字段内右对齐 但是如果我想用动态变量替换这里的常量 11 我该怎么办 您可以使用 字符在其自己的参数中指定字段宽度 printf d some w
  • PHP 从多维数组创建消息线程的多维数组 (IMAP)

    我的问题如下 如果你往下看 你会看到有一个带有消息 ID 的数据结构 然后是包含消息详细信息的最终数据结构 这些详细信息应该从imap fetch overview 消息 ID 来自imap thread 问题是它没有将电子邮件详细信息放在
  • Firestore 如果文档不存在则创建文档,如果存在则跳过

    我想创建 Firestore 文档 如果它们不存在 如果它们确实存在 请跳过它们 不更新 这是流程 var arrayOfRandomIds array of 500 random numbers for var id of arrayOf
  • AWS Athena 上的 OFFSET

    我想在 AWS Athena 上运行查询LIMIT and an OFFSET条款 我认为前者受到支持 而后者不是 有没有办法使用其他方法来模拟此功能 Using OFFSET分页效率非常低 特别是对于像 Presto 这样经常需要执行全表