0

据我所知,我可以重写这个活动记录查询

Some.where("a = :a and b = :b", { :a => params[:a], :b => params[:b] })

这边走:

Some.where(:a => params[:a], :b => params[:b])

现在我需要重写这个查询:

Some.where("a = :a and b > :b", { :a => params[:a], :b => params[:b] })

我怎么才能得到它 ?

我可以使用范围条件:

Some.where(:a => params[:a], :b => params[:b]+1..100000)

但我不能确定在恒定的 100000。

4

1 回答 1

4

我不明白为什么你“需要”重写它。它按原样工作,并且没有办法在基于哈希的条件下正确地做到这一点。

也就是说,如果你不喜欢 SQL 让你的 Ruby 变得一团糟,你可以看看优秀的Squeel gem,它可以让你重写类似的东西

where("name LIKE :name AND salary < :salary", {:name => "A%", :salary => 50000})

作为

where{(name =~ "A%") & (salary < 50000)}

我认为这很酷。

于 2012-11-09T12:09:20.507 回答