轨道3:如何找到与现场可能等于无记录? [英] Rails 3: How to find records with field possibly equals to nil?
本文介绍了轨道3:如何找到与现场可能等于无记录?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想找到所有作曲家
s的 maiden_name
等于 my_maiden_name
?
I would like to find all SongWriter
s with maiden_name
equals to my_maiden_name
?
注意: my_maiden_name
可能零
我想:
SongWriter.where("maiden_name = ?", my_maiden_name)
和它工作正常的情况下除外,其中 my_maiden_name =零
。
and it works fine except the case where my_maiden_name = nil
.
在 my_maiden_name =零
,生成的查询是:
SELECT `song_writers`.* FROM `song_writers` WHERE (maiden_name = NULL)
而不是
SELECT `song_writers`.* FROM `song_writers` WHERE maiden_name IS NULL
我怎么能概括的活动记录查询,以包括案件 my_maiden_name =零
?
推荐答案
使用哈希语法。 ActiveRecord的将做转换为你。
Use the Hash syntax. ActiveRecord will do the conversion for you.
SongWriter.where(:maiden_name => my_maiden_name)
在 my_maiden_name
是零
它会使用 IS NULL
。否则,它会使用 =
。
When my_maiden_name
is nil
it will use IS NULL
. Otherwise it will use =
.
这篇关于轨道3:如何找到与现场可能等于无记录?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文