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

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

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

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

Ruby on Rails

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

Q&A

解決済

2回答

578閲覧

データ存在しないものの検索方法

takeke

総合スコア60

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/08/31 02:19

rails初学者なのですが、コンソールで検索する際に、存在するものの検索はわかったのですが、存在しないものを探すことってできますでしょうか?

例えばですが、Userモデルがid,nameとして、現在存在しているidが1,2,4,8,9,10とします。
この時に、id(1,3,5,7,9)の中で存在しないのはどのidか?って検索することはできますでしょうか?

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

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

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

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

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

guest

回答2

0

irb

1ids = [1,3,5,7,9] 2ids - User.where(id: ids).pluck(:id)

ただ、この方法ですとid集合が現実的な数に限られますね。
1000万件クラスのid集合からないものを・・・みたいなケースですとSQL詳しい人に聞いたほうがよいです。

投稿2020/08/31 02:42

asm

総合スコア15149

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

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

takeke

2020/09/01 10:48

回答ありがとうございます!
guest

0

ベストアンサー

単純に「存在するものを探して引き算する」では物足りないでしょうか?

ruby

1ids = [1, 3, 5, 7, 9] 2not_exists = ids - User.where(id: ids).pluck(:id)

投稿2020/08/31 02:32

maisumakun

総合スコア145930

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

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

takeke

2020/09/01 10:47

回答ありがとうございます! いえ、その考え方がすっと出てきませんでした。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問