ruby – 续集渴望加载单个ORM对象的一些关联
我正在为一个小应用程序构建数据模型,并希望利用某些方法中的急切加载 – 即我事先知道某些关联将被使用的方法.
我已经阅读了.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 希望这会有所启发. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |