我正在尝试使用通过节点js实现的休息服务来获取记录,以填充jquery的自动完成。这是方法
db.collection('publication', function(err, collection) {
collection.distinct('title',{'$or':[{type:'an'},{type:'pub'}]}).toArray(function(err, items) {
res.jsonp(items);
});
});
};
mongo中的查询有效 - >
db.publication.distinct('title',{'$or':[{type:'an'},{type:'pub'}]})
返回[“产品”,“事件”] 但是当我使用find时,结果是不同的, 找到将是 - >
{ "_id" : ObjectId("51fbb2124e49d03810000000"), "title" : "Anuncio" }
{ "_id" : ObjectId("51fbb2ae4e49d03810000001"), "title" : "Evento" }
使用第二种方式自动完成工作,但第一种方式不是
节点中显示的错误是:object不是函数。
最后我需要的是返回一个带有记录的json来填充自动填充,填充如下:
$('#search').autocomplete({
source: function(req, res) {
$.ajax({
url: "http://www.example.com:3000/autocomplete/" + req.term ,
dataType: "jsonp",
type: "GET",
data: {
term: req.term
},
success: function(data) {
res($.map(data, function(item) {
return {
label: item.title,
value: item.title
};
}));
},
error: function(xhr) {
alert(xhr.status + ' : ' + xhr.statusText);
}
});
});
答案 0 :(得分:5)
尝试将函数部分移动到distinct()。
collection.distinct('title',{'$or':[{type:'an'},{type:'pub'}]},function(err, items) {
res.jsonp(items);
});
我遇到了同样的问题,我在这里解决了我的问题:
http://mongodb.github.io/node-mongodb-native/api-generated/collection.html
(搜索关键词' distinct')
事实证明,官方文档可以提供帮助
希望能帮到遇到同样问题的人。
答案 1 :(得分:-3)
应排除搜索中的_id字段
查询:
db.products.find( { qty: { $gt: 25 } }, { item: 1, qty: 1, _id: 0 } )