当前位置 : 主页 > 编程语言 > ruby >

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

来源:互联网 收集:自由互联 发布时间:2021-06-23
我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法. 我已经阅读了.eager方法的the Sequel::Model::Association指南,但它让我有点
我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法.

我已经阅读了.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 ).all
end

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

我的问题:我的构造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

希望这会有所启发.

网友评论