我第一次尝试GraphQL、分页和Rails中的批加载。我需要一些人帮忙调查引擎盖下面发生的事情。我使用GraphQL::Batch。这是我的两个Qraphql类型(精简),表示1对多(has_many,belongs_to pair in AR)关系:

module Types
  class GoalType < Types::BaseObject
    field :id, ID, null: false
    field :title, String
    field :tags_connection, Types::TagType.connection_type

    def tags_connection
      Loaders::RecordLoader.for(::Tag).load_many(object.tag_ids)
    end
  end
end

module Types
  class TagType < Types::BaseObject
    field :id, ID, null: false
    field :name, String
  end
end

下面是查询根实现:

field :goals_connection, Types::GoalType.connection_type, null: false
    def goals_connection
      Goal.all
    end

到目前为止,我可以得到分页列表,并且它工作正常(好吧,我仍然对查询的数量有问题,这比imo要多,但这是另一个问题)。问题是,当我像下面这样运行查询时:

query GoalQuery {
  goalsConnection(first: 2) {
    nodes {
      id
      title
      tagsConnection(first: 2) {
        nodes {
          name
          eventsCounter
        }
      }
    }
  }
}

我看到生成了以下SQL语句:

Goal Load (0.1ms)  SELECT "goals".* FROM "goals" LIMIT ? OFFSET ?  [["LIMIT", 2], ["OFFSET", 0]]
  
Tag Pluck (0.1ms)  SELECT "tags"."id" FROM "tags" WHERE "tags"."goal_id" = ? ORDER BY events_counter desc LIMIT ?  [["goal_id", 1], ["LIMIT", 100]]
  
Tag Pluck (0.2ms)  SELECT "tags"."id" FROM "tags" WHERE "tags"."goal_id" = ? ORDER BY events_counter desc LIMIT ?  [["goal_id", 2], ["LIMIT", 100]]
  
Tag Load (0.2ms)  SELECT "tags".* FROM "tags" WHERE "tags"."id" IN (?, ?, ?, ?, ?, ?, ?)  [["id", 2], ["id", 1], ["id", 3], ["id", 4], ["id", 5], ["id", 6], ["id", 7]]

所以,我的困惑是这里LIMIT的用法。Goal上的第一个查询是根据请求的页面添加LIMITOFFSET。但是,嵌套连接正在设置一个LIMIT = 100,这与我的页面请求没有任何关系,而且我没有在任何地方设置值100(甚至在default_max_page_sizedefault_page_size上也没有)。那么,为什么限制为100,以及如何应用页面大小?一天结束后,我得到了正确的页面,除了顶层实体之外,它都在内存中吗?

我已经更改了查询根实现以预加载连接:

field :goals_connection, Types::GoalType.connection_type, null: false
    def goals_connection
      Goal.preload(:tags)
    end

它去掉了额外的查询,但上面仍然有limit: 100。我没有使用preload的原因是我担心它无法正确应用分页限制,因为我读到你不能对预加载的关联设置约束。但是,现在即使没有预加载,我也看到类似的事情发生了。所以,也许预加载是正确的方式,除了可能我一开始没有正确实现分页?

就数据库查询而言,GraphQL如何将分页应用于嵌套连接?的更多相关文章

  1. GraphQL在react中的应用示例详解

    这篇文章主要为大家介绍了GraphQL在react中的应用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  2. PHP框架Laravel插件Pagination实现自定义分页

    这篇文章主要为大家详细介绍了PHP框架Laravel5.1插件Pagination实现自定义分页的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. GraphQL入门总体创建教程

    这篇文章主要为大家介绍了GraphQL入门总体创建教程示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. SpringBoot集成Graphql Query实战示例

    这篇文章主要为大家介绍了SpringBoot集成Graphql Query实战示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  5. jQuery Pagination分页插件使用方法详解

    这篇文章主要为大家详细介绍了jQuery Pagination分页插件的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  6. js如何使用Pagination+PageHelper实现分页

    本文主要介绍了js如何使用Pagination+PageHelper实现分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  7. CodeIgniter分页类pagination使用方法示例

    这篇文章主要介绍了CodeIgniter分页类pagination使用方法,结合实例形式简单分析了CodeIgniter框架中的分页类pagination基本的配置与使用技巧,需要的朋友可以参考下

  8. jQuery EasyUI Pagination实现分页的常用方法

    这篇文章主要为大家详细介绍了jQuery EasyUI Pagination实现分页的常用方法,感兴趣的朋友可以参考一下

  9. Laravel中GraphQL接口请求频率实战记录

    这篇文章主要给大家介绍了关于Laravel中GraphQL接口请求频率的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  10. jquery pagination分页插件使用详解(后台struts2)

    这篇文章主要为大家详细介绍了jquery pagination 分页插件的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

随机推荐

  1. 如何扩展ATmega324PB微控制器的以下宏寄存器?

    我目前正在学习嵌入式,我有以下练习:展开以下宏寄存器:如果有人解决了这个问题,我将不胜感激,以便将来参考

  2. Python将ONNX运行时设置为返回张量而不是numpy数组

    在python中,我正在加载预定义的模型:然后我加载一些数据并运行它:到目前为止,它仍在正常工作,但我希望它默认返回Tensor列表,而不是numpy数组。我对ONNX和PyTorch都是新手,我觉得这是我在这里缺少的基本内容。这将使转换中的一些开销相同。

  3. 在macOS上的终端中使用Shell查找文件中的单词

    我有一个文本文件,其中有一行:我需要找到ID并将其提取到变量中。我想出了一个RexEx模式:但它似乎对我尝试过的任何东西都不起作用:grep、sed——不管怎样。我的一个尝试是:我为这样一个看似愚蠢的问题感到抱歉,但我在互联网上找不到任何东西:我在SO和SE上读了几十个类似的问题,并在谷歌上搜索了几个教程,但仍然无法找到答案。欢迎提供任何指导!

  4. react-chartjs-2甜甜圈图中只有标题未更新

    我正在使用react-chartjs-2在我的网站中实现甜甜圈图。下面是我用来呈现图表的代码。我将甜甜圈图的详细信息从父组件传递到子组件,所有道具都正确传递。当我在beforeDraw函数外部记录props.title时,它会记录正确的值,但当我在beforeDraw函数内部记录props.title时,它将记录标题的前一个值,从而呈现标题的前值。我在这里做错了什么?

  5. 如何在tkinter中使用Python生成器函数?

    生成器函数承诺使某些代码更易于编写。但我并不总是知道如何使用它们。假设我有一个斐波那契生成器函数fib(),我想要一个显示第一个结果的tkinter应用程序。当我点击“下一步”按钮时,它会显示第二个数字,依此类推。我如何构建应用程序来实现这一点?我可能需要在线程中运行生成器。但如何将其连接回GUI?

  6. 如何为每次提交将存储库历史记录拆分为一行?

    我正在尝试获取存储库的历史记录,但结果仅以单行文本的形式返回给我。

  7. 尝试在颤振项目上初始化Firebase时出错

    当尝试在我的颤振项目上初始化firebase时,我收到了这个错误有人知道我能做什么吗?应用程序分级Gradle插件Gradle项目颤振相关性我已经将firebase设置为Google文档已经在另一个模拟器上尝试过,已经尝试过创建一个全新的模拟器,已经在不同的设备上尝试过了,已经尝试了特定版本的firebase,已经尝试添加但没有任何效果,已经在youtube上看到了关于它的每一个视频,该应用程序在android和iOS两个平台上都抛出了这个错误

  8. 在unix中基于当前日期添加新列

    我试图在unix中基于时间戳列在最后一个单元格中添加一个状态列。我不确定如何继续。

  9. 麦克斯·蒙特利。我一直得到UncaughtReferenceError:当我在终端中写入node-v时,节点未定义

    如果这是您应该知道的,请确认:我已将所有shell更改为默认为zsh。当我在终端中写入node-v时,我一直收到“UncaughtReferenceError:nodeisnotdefined”。但它显示节点已安装。我是个新手,在这方面经验不足。

  10. 如何在前端单击按钮时调用后端中的函数?

    那么如何在后端添加一个新的端点,点击按钮调用这个函数。

返回
顶部