有没有更好的方式来写这个:
User.where(:genre_id => Genre.where(:name =>‘声音’).first.id).first.first_name
基本上,我试图返回流派‘声学’的所有用户。
如果有用户使用声学设置,则上面的设置将起作用。但如果我这么做了:
User.where(:genre_id => Genre.where(:name => 'Pop').first.id).first.first_name
我将得到一个错误,因为没有与流行流派相关联的用户...
有什么建议可以让它工作吗?
发布于 2010-11-13 20:58:29
一般来说,多对多关系在mongo中真的很糟糕(你为has_one/has_many付出的代价太棒了)
我假设问题是Genre.where(:name => 'Pop').first返回nil?我会这么做的
User.where(:genre_id => g).first.first_name if g = Genre.where(:name => 'Pop').first.try(:id)或者如果大量的单行表达式不是你喜欢的
g = Genre.where(:name => 'Pop').first.try(:id)
if g
User.where(:genre_id => g).first.first_name
end发布于 2010-11-13 21:02:51
通常的嵌套where不能工作吗?
User.where(:genre => { :name => 'Pop' })发布于 2010-11-13 21:05:01
你可以尝试使用find而不是where来查找流派:
User.where(:genre_id => Genre.find(:first, :conditions => { :name => 'Pop' }))即使当Genre.find返回nil时,这也应该起作用。
https://stackoverflow.com/questions/4172484
复制相似问题