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

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

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

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

Ruby on Rails

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

Q&A

解決済

Railsで正規表現を使い、一致したレコードを取り出す方法を教えていただけないでしょうか?

koume
koume

総合スコア458

Ruby

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

Ruby on Rails

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

1回答

0グッド

0クリップ

1204閲覧

投稿2018/05/21 05:32

Rails5.1.3でWebアプリケーション制作の勉強をしています。
Customersテーブルのemailカラムで先頭がaから始まるレコードのidをwhereメソッドで全て取り出したいのですが
わからないのでどなたか教えていただけないでしょうか?宜しくお願いします。

members = Customer.where(email: ※※※※※).pluck(:id)

※※※※※の部分に正規表現の =~ /^a/ を使ってうまく取り出せないのかな?と思いましたが
よくわかりません。
他に方法などがあれば教えていただけないでしょうか?宜しくお願いします。

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

回答1

0

ベストアンサー

データベースエンジンによっては正規表現による検索にも対応していますが、Railsでは対応していません。

そして、SQL標準にあるLIKE検索もRails標準では対応しない(とDHH氏が決めた)ので、Gemなしでは文字列、あるいはArelで書くことになります。

ruby

1Customer.where("email LIKE 'a%'")

もっとも、多用するのであれば何かしらGemを入れたほうがいいかもしれません。

投稿2018/05/21 05:52

maisumakun

総合スコア141550

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

koume

2018/05/21 06:25

回答ありがとうございました。おかげさまで、思うようにidを取り出すことに成功しました。 今後とも宜しくお願いします。

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

ただいまの回答率
86.02%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Ruby

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

Ruby on Rails

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