ruby-on-rails – Rails – 给定一组用户 – 如何获得电子邮件的
我有以下内容:
@users = User.all 用户有几个字段,包括电子邮件 我希望能够获得所有@users电子邮件的列表. 我试过了: @users.email.all but that errors w undefined 想法?谢谢 解决方法
(按流行需求,发布作为真实答案)
我不喜欢fl00r’s solution的是它在数据库中为每个记录实例化一个新的User对象;这只是不规模.这对于一个只有10封电子邮件的表来说非常棒,但是一旦你开始涉及成千上万,你就会遇到问题,主要是Ruby的内存消耗. 通过在模型上使用connection.select_values以及一点ARel优点,可以解决这个小问题: User.connection.select_values(User.select("email").to_sql) 这将为您提供数据库中电子邮件地址的直接字符串.没有对用户对象感到不满,并且比直接的User.select(“email”)查询更好地扩展,但我不会说它是“最佳规模”.可能有更好的方法来做到这一点,我还没有意识到. 重点是:String对象将使用比User对象更少的内存,因此您可以拥有更多内存.它也是一个更快的查询,并没有很长的路要走(运行查询,然后映射值).哦,地图也需要更长的时间. 如果您使用的是Rails 2.3 … 然后你必须手动构建SQL,我很遗憾地说. User.connection.select_values("SELECT email FROM users") 只是提供了Rails 3提供的帮助程序的另一个示例. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |