我知道这会删除重复项:
@email.distributions.map(&:zip_code) & CardSignup.all.map(&:zip_code)
但我想做同样的事情,我发现任何匹配的东西,但它也向我显示重复。
有什么想法吗?
我正在尝试查找已注册卡片的人数,这些卡片的邮政编码与我放置的邮政编码首选项相匹配。
答案 0 :(得分:7)
Array#reject
再次救援!与Array#map
类似,它接受块,允许您执行以下操作:
zip_codes = CardSignup.all.map(&:zip_code)
@email.distributions.reject{|o| !zip_codes.include?(o.zip_code)}
哦,但是,当然,如果你想找到更优雅的方式,总要考虑像你一样的运营商。 &
将返回一个包含两者中的对象的新数组,|
将加入并删除重复项。
ruby-1.9.2-p0 > [1,2] | [2,3]
=> [1, 2, 3]
ruby-1.9.2-p0 > [1,2] & [2,3]
=> [2]
编辑:正如Tokland在评论中所说,因为这适用于Rails模型,您可能需要考虑将其作为选择。像这样 -
zip_codes = CardSignup.all.map(&:zip_code)
@email.distributions.where('zip_code IN (?)', zip_codes)
或者,使用INNER JOIN进行操作。看起来不漂亮。
@email.distributions.joins('INNER JOIN card_signups ON card_signups.zip_code = email_distributions.zip_code').all
(如果@ email.distributions的表格是email_distributions ..)