首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我需要返回流派‘声学’的所有用户

我需要返回流派‘声学’的所有用户
EN

Stack Overflow用户
提问于 2010-11-13 20:25:38
回答 3查看 270关注 0票数 1

有没有更好的方式来写这个:

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

我将得到一个错误,因为没有与流行流派相关联的用户...

有什么建议可以让它工作吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-11-13 20:58:29

一般来说,多对多关系在mongo中真的很糟糕(你为has_one/has_many付出的代价太棒了)

我假设问题是Genre.where(:name => 'Pop').first返回nil?我会这么做的

代码语言:javascript
复制
User.where(:genre_id => g).first.first_name if g = Genre.where(:name => 'Pop').first.try(:id)

或者如果大量的单行表达式不是你喜欢的

代码语言:javascript
复制
g = Genre.where(:name => 'Pop').first.try(:id)
if g
  User.where(:genre_id => g).first.first_name 
end
票数 2
EN

Stack Overflow用户

发布于 2010-11-13 21:02:51

通常的嵌套where不能工作吗?

代码语言:javascript
复制
User.where(:genre => { :name => 'Pop' })
票数 0
EN

Stack Overflow用户

发布于 2010-11-13 21:05:01

你可以尝试使用find而不是where来查找流派:

代码语言:javascript
复制
User.where(:genre_id => Genre.find(:first, :conditions => { :name => 'Pop' }))

即使当Genre.find返回nil时,这也应该起作用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4172484

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档