🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

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

Q&A

解決済

2回答

10989閲覧

Ruby on Railsでデータベースからcurrent_user以外のuserを全部取得する方法

dongw

総合スコア119

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

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

0グッド

0クリップ

投稿2017/01/18 09:58

Ruby on Railsにて

Controllerにて、Userというデータベースから自分以外のuserをすべて取得する方法を教えてほしいです。

User.all

User.allからcurrent_userの値を除外するだけで取得できると思うのですが思いつかないです。よろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

where や where.not で実現できると思います。
current_user.id で current_user の id がわかるとおもうので、
id が その値以外を探せばよいです。

次の操作例をご覧ください。(crrent_user.id が 2 だとおもってください)

$ bundle exec rails c irb(main):010:0> User.all.select(:id) User Load (0.2ms) SELECT "users"."id" FROM "users" => #<ActiveRecord::Relation [#<User id: 1>, #<User id: 2>, #<User id: 3>]> irb(main):011:0> User.where('id != ?', 2).select(:id) User Load (0.3ms) SELECT "users"."id" FROM "users" WHERE (id != 2) => #<ActiveRecord::Relation [#<User id: 1>, #<User id: 3>]> irb(main):012:0> User.where.not(id: 2).select(:id) User Load (0.2ms) SELECT "users"."id" FROM "users" WHERE ("users"."id" != ?) [["id", 2]] => #<ActiveRecord::Relation [#<User id: 1>, #<User id: 3>]>

投稿2017/01/18 15:03

katoy

総合スコア22324

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

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

dongw

2017/01/19 07:23

回答ありがとうございました。 where.notを使って無事取得することができました。ありがとうございました!
guest

0

katoyさんがすでに説明済みですが。。。
一言で答えると、これ。

ruby

1User.where.not(id: current_user.id)

投稿2017/01/19 02:51

IPU

総合スコア283

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問