以下代码有效,但运行了太多我喜欢的 SQL 语句;
User.includes([:profile,:roles]).select("id, email, created_at, confirmed_at, countries.name").find_in_batches do |users|
users.map{|u| # In here I access profile.country.name}
end
这样做的目的是获取用户信息以及一些个人资料信息并将其转换为 csv 格式。
在.map
我调用的内部,profile.country.name
这很好,但 Rails 正在运行一个额外的 SQL 调用来查找名称,我想要做的是在我的初始查找中捕获这些信息。
我的问题是因为country
是链接到profile
而不是user
我不能将它添加到我的.includes
,因为它不认为它是一个可链接的表。我能做些什么来强制包含加入链接到的表profile
吗?
相关型号信息如下;
用户:
has_one :profile, dependent: :destroy
轮廓:
belongs_to :user
belongs_to :country
国家:
has_many :profiles