ruby – 续集渴望加载单个ORM对象的一些关联

ruby – 续集渴望加载单个ORM对象的一些关联,第1张

概述我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法. 我已经阅读了.eager方法的the Sequel::Model::Association指南,但它让我有点困惑.一个典型的例子可能是: Artist.eager( :albums => :tracks ).all 它只使用三个查询加载所有Artist对象及其预加载的所有专辑字段,并预加载 我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法.

我已经阅读了.eager方法的the Sequel::Model::Association指南,但它让我有点困惑.一个典型的例子可能是:

Artist.eager( :albums => :tracks ).all

它只使用三个查询加载所有Artist对象及其预加载的所有专辑字段,并预加载所有曲目.到现在为止还挺好.

但是说我想通过其主键加载一个艺术家,并且仍然预先加载了专辑曲目(仍然有三个查询,可能比跟踪每个专辑的关联少很多)?我看不到任何这样的例子.一点点实验给了我

Artist.eager( :albums => :tracks ).where( :ID => ID ).all.first

这似乎至少有效.我通过调用此方法确认了急切加载,然后关闭了数据库,并显示我仍然可以访问关联.

但是,我觉得我错过了一些东西.该构造必须将主键传递给where子句,得到一个完整的数据集然后要求第一个项目似乎很尴尬.我正在寻找这样的东西:

Artist.eager( :albums => :tracks )[ ID ]

. . .一种简单的方式来声明我想加载一个对象,并急切加载它的一些关联.

我发现我可以创建这样的自定义关联:

def eager_albums  albums_dataset.eager( :tracks ).allend

但这很难使用,因为代码必须以不同的方式请求关联.

我的问题:我的构造Artist.eager(:albums =>:tracks).where(:ID => ID).all.first做了我认为它在续集中所做的事情,我可以做得更好(更简单的代码) ?

解决方法 调用Artist.eager(:albums =>:tracks).where(:ID => ID).all.first获取ID等于’ID’的所有艺术家,然后从结果数组中提取第一个艺术家(调用都实现了数组).通常,此查询仅返回具有单个艺术家的数组.

直到你实际上要求关联art.albums或协会之外的关系才能运行其他查询.

你可以做Artist.eager(:albums =>:tracks).where(:ID => ID).first

我使用tactical eager loading plugin因此几乎没有必要使用eager,因为它检测到何时从作为更大结果集的一部分的模型实例使用关联,并自动加载整个结果集的相关模型.您的查询现在变为Artist [ID]或Artist [ID] .albums.all

我使用的另一个方便的插件是association proxies plugin,所以我不必处理使用association.some_array_method vs association_dataset.some_ds_method

最后,dataset associations plugin允许您描述从某个模型或模型类开始的查询,并通过关联链接到目标模型,同时允许您在此过程中定义约束(或不约束).

例如,“在英国出生的艺术家过去两周发布的任何专辑中查找超过3分钟的所有曲目”:

Artist.where(country_of_birth:’UK’).albums.where {release_date> Date.today – 14} .tracks.where {duration> 3.minutes} .all

希望这会有所启发.

总结

以上是内存溢出为你收集整理的ruby – 续集渴望加载单个ORM对象的一些关联全部内容,希望文章能够帮你解决ruby – 续集渴望加载单个ORM对象的一些关联所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/langs/1235910.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存