0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

#Ruby on #Rails で has_one belongs_to has_many などの association を持ったテーブルを対象に OR 検索がしたい

Last updated at Posted at 2019-07-02

単一条件の場合であれば、単に joins してあげれば、結合できないレコードは除かれるので、それで済むはず。

User.joins(:books)
User.joins(:lovers)

でも ORの複合的な条件だと、いちど LEFT OUTER JOIN をしてからじゃないt、うまくいかない気がした。

なのでまずは複数のテーブルを LEFT JOIN してから、親テーブルとの関連レコードが存在して「結合できた」ものだけを絞り込んで見た。

User
  .left_joins(:books)
  .left_joins(:lovers)
  .where.not(books: {user_id: nil}).or(
	User
	  .left_joins(:books)
	  .left_joins(:lovers)
	  .where.not(lovers: {user_id: nil})
  )
  .distinct

SQLはこんな感じ。

=> "SELECT DISTINCT `users`.* FROM `users` LEFT OUTER JOIN `books` ON `books`.`user_id` = `users`.`id` LEFT OUTER JOIN `lovers` ON `lovers`.`user_id` = `users`.`id` WHERE (`books`.`user_id` IS NOT NULL OR `lovers`.`user_id` IS NOT NULL)"

最後に distinct しているのは、has_many のテーブルを left join した時に、結果が元の user 数よりも増えるので、ユニークにしている。

Original by Github issue

チャットメンバー募集

何か質問、悩み事、相談などあればLINEオープンチャットもご利用ください。

Twitter

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?