でユニークを取得するために減らすMongoDBのマップの日付と番号でグループにしようとした日付/日
私の文書
{ "_id" : ObjectId("4f956dee76ddb26752026e8f"), "request" : "default", "options" : "1", "keyword" : "somekey", "number" : "5b234b79-4d70-437e-8eef-32a2941af40a", "date" : "20120423200446", "time" : 1335193066 }
私のクエリ
map = "function() { var date = new Date(this.time * 1000); var key = date.getFullYear() + date.getMonth() + date.getDate(); emit({day : key, number: this.number}, {count: 1}); }"
reduce = "function(key, values) { var count = 0; values.forEach(function(v) { count += v['count']; }); return {count: count}; }"
db.txtweb.mapReduce(map, reduce, {out: "pageview_results"});
私のエラー
uncaught exception: map reduce failed:{ "errmsg" : "ns doesn't exist", "ok" : 0 }
私は何をwronを把握することはできませんg、しかし、私はそれが日付機能で何かをしていると思う。
アイデア
nsが存在しません。存在しないデータベースまたはコレクションにアクセスしています。名前を確認する...これが問題だった。ありがとう – Anand
私はnodejsエラーでそれを実行しようとすると、以下のエラーが表示されます:MongoError:例外:マップ呼び出しが失敗しました:JSエラー:ReferenceError:クローン が定義されていませんnofile_b:1 – peter
はい。クローンは元の日付オブジェクトの変更を避けるために使用されます。私はクローン機能の実装をスキップしました。代わりにこれを使うことができます - 新しいDate(this.getTime()); – Anton