def action_search() param = { :where=>{ :age=>20 } } results = @person.search( param ) results.each {|data| puts data.values, "<br>" } end
複合条件。HashキーをSymbolで指定した場合は、常に=(イコール)で比較します。
:where=>{ :name=>"Ishikawa", :age=>20 }
NULL条件の指定。( SQLでは、name is nullとなる)
:where=>{ :name=>nil }
以上、以下などの指定
:where=>{ "age <"=>20 }
Like検索
:where=>{ "name like"=>"I%" }
パラメータに、:order_byキーを追加します。
def action_search() param = { :order_by=>"age desc" } results = @person.search( param ) results.each {|data| puts data.values, "<br>" } end
複数のオーダー指定は、配列で指定します。
:order_by=>["age desc", "name asc"]
リミット、オフセット
param = { :limit=>2, :offset=>5 }
リミットを指定した場合は、検索後、以下のメソッドが有効になります。
# 前ページのオフセット値を得る。前ページがなければnil。 @person.get_previous_offset() # 次ページのオフセット値を得る。次ページがなければnil。 @person.get_next_offset()]
全件数の同時取得
def action_search() param = { :total_rows=>true } @person.search( param ) p @person.search_condition[:total_rows] end
コード例
@persist.select( "t1.*, t2.note" "from t1 inner join t2 using(id) where d=CURRENT_DATE", :order_by=>"create_date desc", :limit=>10, :offset=>20 )
生成されるSQL
select t1.*, t2.note from t1 inner join t2 using(id) where d=CURRENT_DATE order by create_date desc limit 10 offset 20;