更正遗留代码,有一个对象LandingPage
的索引,其中大多数列应该是可排序的,但不是。大多数情况已得到纠正,但很少有专栏继续给我带来麻烦。
这些列是需要汇总的列,因为基于其他文档的数量。为了简化对问题的解释,我只讲其中一个称为Visit
,因为其余的代码将只是重复的。
代码获取排序并分页的数据,然后在返回json之前使用LandingPage
方法修改每个对象。就像这样,我无法修改。
因此,我需要进行汇总(以LandingPage
计数对Visit
进行排序),然后将该对象作为LandingPage
实例,以使旧代码可以在其上工作。
问题是无法将Mongoid :: Document转换为LandingPage实例
Mongoid::Errors::UnknownAttribute:
Message:
unknown_attribute : message
Summary:
unknown_attribute : summary
Resolution:
unknown_attribute : resolution
def controller_function
landing_pages = fetch_landing_page
landing_page_hash[:data] = landing_pages.map do |landing_page|
landing_page.do_something
# Do other things
end
render json: landing_page_hash
end
def fetch_landing_page
criteria = LandingPage.where(archived: false)
columns_name = params[:columns_name]
column_direction = params[:column_direction]
case order_column_name
when 'visit'
order_by_visits(criteria, column_direction)
else
criteria.order_by(columns_name => column_direction).paginate(
per_page: params[:length],
page: (params[:start].to_i / params[:length].to_i) + 1
)
end
def order_by_visit(criteria, order_direction)
def order_by_visits(landing_pages, column_direction)
LandingPage.collection.aggregate([
{ '$match': landing_pages.selector },
{ '$lookup': {
from: 'visits',
localField: '_id',
foreignField: 'landing_page_id',
as: 'visits'
}},
{ '$addFields': { 'visits_count': { '$size': '$visits' }}},
{ '$sort': { 'visits_count': column_direction == 'asc' ? 1 : -1 }},
{ '$unset': ['visits', 'visits_count'] },
{ '$skip': params[:start].to_i },
{ '$limit': params[:length].to_i }
]).map { |attrs| LandingPage.new(attrs) { |o| o.new_record = false } }
end
end
LandingPage.new(attributes)
,并且实例已创建且有效。is_a?(hash)
将返回true。如何使Aggregate的返回成为LandingPage的有效实例?
聚合管道是由Ruby MongoDB驱动程序而不是Mongoid实现的,因此不会返回Mongoid模型实例。
documentation中提供了一个如何获取Mongoid模型实例的示例。