スポンサーサイト

上記の広告は1ヶ月以上更新のないブログに表示されています。
新しい記事を書く事で広告が消せます。

Tag:スポンサー広告 

【Ruby】ActiveRecordでSQLのINのプレースホルダに配列を渡すといいことがある

RailsのActiveRecordを使っていてIN句を使いたいとき

たとえば


Hoge.where(["user_id IN ('2', '3')"])


みたいに「user_idが2または3のレコードを抽出したい」といった場合がありますよね
コレをベタにやってしまうと条件の値(この例だと2と3)が入った配列の中身をそれぞれクォーテーションでかこって、カンマでつなげて。。。
みたいな面倒なことしなきゃいけないと思ってしまいますが。

プレースホルダを使うといい感じにやってくれます。


values = [2, 3]
Hoge.where(["user_id IN (?)", values])


こちらのやり方でも上記と全く同じSQL文が発行されます
これを知っておくともうINに渡す値を面倒な文字列連結とかして作らないで大丈夫です。

簡単なメモとして残しておきます。
スポンサーサイト
テーマ : プログラミング
ジャンル : コンピュータ

Tag:Ruby  Trackback:0 comment:0 

Comment

comment form
(編集・削除用):
管理者にだけ表示を許可
プロフィール

6rats

Author:6rats
こんにちは、ITベンチャーで働くエンジニアです
主に自分の周りで起きた技術的なことをメモとして書き残して行きます。
Android以外にもRuby/Ruby on RailsやFuelPHPなどなどたまにやります。基本的なスタンスとしては興味があるもしくは必要になったらいろんなことにチャレンジします。
最近はiOSアプリ開発を始めています。

購読
follow us in feedly
個人プロダクト

Androidアプリ

Twitterクライアント

Webアプリケーション

EcPriceWatch(Amazon価格の推移を計測、最安値を知らせるサービス)
Google AdSense
ブログ村
にほんブログ村 IT技術ブログへ
にほんブログ村
ブロとも申請フォーム

この人とブロともになる

上記広告は1ヶ月以上更新のないブログに表示されています。新しい記事を書くことで広告を消せます。