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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Q&A

解決済

1回答

243閲覧

RANDメソッドでとってきている値に制約をかけたい

hidekie

総合スコア27

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

0グッド

0クリップ

投稿2018/04/17 17:40

前提・実現したいこと

ランダムでとってきているuser情報の中で現在ログインしているuserの情報だけは出さないように実装したい

ここに質問の内容を詳しく書いてください。
現在ある従業員が他の従業員へ評価をつけるシステム(tinder風)をruby on rails で作っています。
evaluations_controller.rbでランダムに情報をとってきているのですが上記に示した通り現在いるuser全てをランダムでとってきてしまっています。
しかし評価システムなので自分の評価欄をだす必要はないのでログインしているuser自身の情報は@avatarに入れないようにしたいです。
現状それを可能にするようなメソッドがわからないのでどなたが教えてもらえるとありがたいです。
■■な機能を実装中に以下のエラーメッセージが発生しました。

evaluations_controller.rb

class EvaluationsController < ApplicationController def index @evaluation = Evaluation.new @avatar1 = User.where.not(family_name: "田中" ).select(:family_name) @avatar = User.order("RAND()").first end def create @evaluation = Evaluation.create(create_params) # binding.pry @evaluation.save redirect_back(fallback_location: user_evaluations_path(current_user, @avatar)) end private def create_params params.require(:evaluation).permit(:rate).merge(reviewer_id: params[:reviewer_id], user_id:current_user.id) end end

補足情報(FW/ツールのバージョンなど)

機能的な面では全て完成していてエラーは特に出ていないです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

下記のような感じでうまくいきませんか?

Ruby

1User.where.not(id: current_user.id).order("RAND()").first

Userのカラムが"id"でなければ、適当に変えてみて下さい。

投稿2018/04/17 22:21

編集2018/04/18 11:36
raccy

総合スコア21735

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

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

hidekie

2018/04/18 00:28

下記のようなエラーが出てしまいます。 Mysql2::Error: Unknown column 'users.user_id' in 'where clause': SELECT `users`.* FROM `users` WHERE (`users`.`user_id` != 7) ORDER BY RAND() LIMIT 1
raccy

2018/04/18 11:37

回答を書き換えました。 たぶん、usersのidがcurrent_userのidと一緒かどうかを見る形になると思うので、これでいけるかと思います。
hidekie

2018/04/18 13:10 編集

エラーが出ずにやりたい機能が実装できました、ほんとにありがとうございます。 またこのようなメソッドの使い方でできることを知り勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問