首页 > 解决方案 > 如何在连接表上/使用连接表编写条件?

问题描述

有两种模型 Ticket 和 Account。帐户有很多票。我正在尝试为每个帐户获取最后创建的票证。

accounts = Account.where(:deleted => false).pluck(:id)    
tickets = Ticket.left_outer_joins(:account)
    .where(:account_id => accounts)
    .order(created_at: :desc)

  ticket_ids = Array.new
  accounts.each do |account|
    ticket = tickets.where(:account_id => account).order(created_at: :desc).limit(1).first
    if !ticket.blank?
      ticket_ids.push(ticket.id)
    end
  end

  @tickets = tickets.where(:id => ticket_ids).order(created_at: :desc)

上面的代码有效,@tickets 包含预期的输出。但问题是上面的代码花费了很多时间。有没有办法在获取查询本身中完成所有这些?或者有什么办法可以优化吗?

我正在使用的数据库:Mysql

标签: mysqlruby-on-railsrubyactiverecordrails-activerecord

解决方案


ticket_ids = Ticket.order(created_at: :desc).group_by(&:account_id).values
@tickets = Ticket.where(id: ticket_ids)

推荐阅读