如何将此查询转换为ActiveRecord(Rails 5)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何将此查询转换为ActiveRecord(Rails 5)相关的知识,希望对你有一定的参考价值。

我有一个SQL查询,如下所示:

SELECT user_id, group_id
    FROM boats
    WHERE is_docked = 1
    AND (
      dock_id IS NULL
      OR
      dock_2_id IS NULL
    )

我在ActiveRecord中最接近的是:

Boat.where(is_docked: 1).where(dock_id: nil).or(Boat.where(dock_id_2:nil))

从上面生成的SQL语法不是我所期望的。什么是正确的方法呢?

答案
Boat.where('is_docked = ? AND (dock_id IS NULL OR dock_2_id IS NULL)', 1,).select(:property_id, :player_id)

要么

Update Boat Model

class Boat < ApplicationRecord
  scope :docked, -> { where('is_docked = ?', 1 }
  scope :with_unassigned_dock, -> { where('dock_id IS NULL OR dock_2_id IS NULL') }
end

new query

Boat.docked.with_unassigned_dock.select(:property_id, :player_id)

以上是关于如何将此查询转换为ActiveRecord(Rails 5)的主要内容,如果未能解决你的问题,请参考以下文章

如何将此 SQL 查询转换为 SQLAlchemy

如何将此codeigniter查询转换为选择更新

如何将此查询转换为 Hive SQL?

如何将此 sql 查询转换为 mongodb?

如何将此 SQL 查询转换为 NSFetchRequest

如何将此 SQL 内部联接查询转换为 LINQ 语法?