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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Cloud9

Cloud9は、クラウドからのプログラミングが可能になるWebサービス。IDEとしての機能が搭載されており、GitHubやHerokuなど他ツールとの連携も可能です。ブラウザ上で動くため、デバイスに関係なく開発環境を準備できます。

Ruby on Rails 5

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

Ruby on Rails

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

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

0回答

1068閲覧

Userとhas_many関係のカラムの値で OR検索して、その数が多い順に表示する。

sunegex

総合スコア49

Cloud9

Cloud9は、クラウドからのプログラミングが可能になるWebサービス。IDEとしての機能が搭載されており、GitHubやHerokuなど他ツールとの連携も可能です。ブラウザ上で動くため、デバイスに関係なく開発環境を準備できます。

Ruby on Rails 5

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

Ruby on Rails

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

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2018/02/23 02:46

編集2022/01/12 10:55

前提・実現したいこと

Cloud9上でRuby on Railsを学ぶ目的で、音楽好きのためのSNSを作っています。
モデルは表(1)の2つです。
各ユーザーが複数のお気に入りを持っていて、
一つのお気に入りに一つずつの曲名と歌手名が保存されているという感じです。

モデル関係カラム
User1id, name, 他
Favoritetitle, artist

表(1)モデルとカラムと関係

ユーザー検索のためのフォームにBootstrapのTokenfieldを使用しています。
トークンの値と一致するartistかtitleを持つ、Userを検索して表示するという流れです。

トークンはAjaxを使ってparams[:search]に『 | 』で区切られた文字列として入ります。
以下のコードで、ここまでは実装することが出来ました。

def self.search(search) if search != '' patterns = search.split("|") #searchを配列に where_body = '' patterns.each do | pattern | fixed_pattern = pattern.gsub("'", "''") where_body += ' OR ' unless where_body.blank? where_body += "favorites.song LIKE '%#{fixed_pattern}%' OR favorites.artist LIKE '%#{fixed_pattern}%'" end User.includes(:favorites).where(where_body) else User.all end end

そして、表示する事が出来たので、次はこのUserの並べ替えをしようとしています。
並べ替えの規則を『トークンの値と 各Userが持つFavoriteのカラム(title, artist) とが一致する数の多い順』
というようにしたいのですが、どのように実装するのが良いのでしょうか?

初心者のうえ、抽象的な質問で申し訳ないのですが、よろしくお願いします。

環境

Cloud9 Ruby '2.0.0' Rails '4.0.5'

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問