加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-17 01:33:52 所属栏目:百科 来源:网络整理
导读:我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法. 我已经阅读了.eager方法的the Sequel::Model::Association指南,但它让我有点困惑.一个典型的例子可能是: Artist.eager( :albums = :tracks ).a
我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法.

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

希望这会有所启发.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读