質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1663閲覧

【Ruby on Rails】アソシエーション済みの状態で片方のテーブルにデータがあるかないかを条件に検索したい

pecchan

総合スコア555

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2017/12/31 09:04

Ruby on Rails初心者です。

社員マスタと所属マスタがあります。
※1社員は複数所属を持ちます

社員一覧から、所属がまだ未設定の社員を抽出したいですのですが
Controllerにて検索条件(パラメータ)を設定する具体的な記述が分かりません。

分かる方教えていただけないでしょうか?

モデル

ruby

1 2#社員 3class Employee < ApplicationRecord 4 has_many :emp_groups, dependent: :destroy 5 accepts_nested_attributes_for :emp_groups, reject_if: :all_blank, allow_destroy: true 6end 7 8#所属 9class EmpGroup < ApplicationRecord 10 belongs_to :employee 11end 12

ビュー

ruby

1 <%= search_form_for(@q, url: employees_path, html: { method: :get, class: 'form-horizontal', role: 'form' }) do |f| %> 2 3 <div class="col-sm-8 col-xs-offset-2"> 4 <div class="row row_input"> 5 <%= select_tag(:hoge, options_for_select([['所属無し', '0'], ['所属有り', '1']], selected: params[:hoge] || '0'), class: 'form-control') %> 6 </div> 7 </div> 8 9 <button class="btn btn-default btn-primary" type="submit"><i class="fa fa-search"></i>検索</button> 10 11 <% end %>

コントローラ

ruby

1class EmpGroupsController < ApplicationController 2 3 def index 4 5 if params[:hoge] == '0' || params[:hoge].nil? 6 #??? 7 elsif params[:hoge] == '1' 8 #???? 9 end 10 11 end 12 13 14end 15

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Railsにおいてアソシエーション先の情報を一緒に取得したり、絞り込んだりする場合にはjoinsincludesを利用することができます。

12 テーブルを結合する | Active Record クエリインターフェイス | Rails ガイド

今回の場合はEmployeeテーブルを読む際にEmpGroupも取得してそこの情報を読みますので、SQLではJOINすることになります。今回はEmpGroupに紐付かないEmployeeがいるのでLEFT OUTER JOINして紐付かないレコードも取得する必要があります。

Rails5以降でLEFT OUTER JOINするのにはleft_joinsが利用できますので上記の回答は以下のようになります。

12.2 left_outer_joins | Active Record クエリインターフェイス | Rails ガイド

ruby

1Employee.left_joins(:emp_groups).where(emp_groups: { id: nil })

以下のようなSQLが発行されます。

sql

1SELECT `employees`.* FROM `employees` LEFT OUTER JOIN `emp_groups` ON `emp_groups`.`employee_id` = `employees`.`id` WHERE `emp_groups`.`id` IS NULL

投稿2017/12/31 15:46

ashphy

総合スコア31

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pecchan

2018/01/01 03:20 編集

ashphy様 分かりやすい解説まで有難う御座いました( ;∀;) 今後にも活かします!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問