轨道3:如何找到与现场可能等于无记录? [英] Rails 3: How to find records with field possibly equals to nil?

查看:107
本文介绍了轨道3:如何找到与现场可能等于无记录?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想找到所有作曲家 s的 maiden_name 等于 my_maiden_name

I would like to find all SongWriters 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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆