var user = Meteor.users.find()。fetch; 这会返回一个预期的但是我应该如何只检索users集合中所有用户的emails.address字段?
答案 0 :(得分:2)
这是一个可能的解决方案:
var emails = _.chain(Meteor.users.find().fetch())
.pluck('emails')
.flatten()
.pluck('address')
.value();
这将为您提供一个详细的电子邮件列表,但请注意,在meteor用户可以有多个电子邮件地址(如果您的UI支持)。通过上面的示例,将返回所有这些。
答案 1 :(得分:0)
一个简单的答案是:
db.users.find({},{ "emails.address" : 1});
这会产生这样的结果:
{ "_id" : "caGts2niaDyS6TbYJ", "emails" : [ { "address" : "asoldfj@bigglie.com" } ] }
{ "_id" : "g5oPp4ReDCwuuW8yn", "emails" : [ { "address" : "blogsalfd@sag.com" } ] }
{ "_id" : "ge9YyFehBMN7q3xQ9", "emails" : [ { "address" : "hag@toldyou.com" } ] }
如果你不想要_id:
db.users.find({},{ "emails.address" : 1, "_id": 0});
产生:
{ "emails" : [ { "address" : "asoldfj@bigglie.com" } ] }
{ "emails" : [ { "address" : "blogsalfd@sag.com" } ] }
{ "emails" : [ { "address" : "hag@toldyou.com" } ] }
David Weldon正确地指出,电子邮件地址字段实际上是一个数组,因此您可以在该字段中容纳多个电子邮件。
但是,如果您知道它只包含一封电子邮件,您可以使用它并进行搜索而无需担心阵列。例如,以下内容将生成一条记录:
Meteor.users.findOne({ "emails.address" : 'asoldfj@bigglie.com' });