123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- // import async to make control flow simplier
- var async = require('async');
- // import the rest of the normal stuff
- var mongoose = require('../../lib');
- require('./person.js')();
- var Person = mongoose.model('Person');
- // define some dummy data
- var data = [
- {
- name: 'bill',
- age: 25,
- birthday: new Date().setFullYear((new Date().getFullYear() - 25)),
- gender: 'Male',
- likes: ['movies', 'games', 'dogs']
- },
- {
- name: 'mary',
- age: 30,
- birthday: new Date().setFullYear((new Date().getFullYear() - 30)),
- gender: 'Female',
- likes: ['movies', 'birds', 'cats']
- },
- {
- name: 'bob',
- age: 21,
- birthday: new Date().setFullYear((new Date().getFullYear() - 21)),
- gender: 'Male',
- likes: ['tv', 'games', 'rabbits']
- },
- {
- name: 'lilly',
- age: 26,
- birthday: new Date().setFullYear((new Date().getFullYear() - 26)),
- gender: 'Female',
- likes: ['books', 'cats', 'dogs']
- },
- {
- name: 'alucard',
- age: 1000,
- birthday: new Date().setFullYear((new Date().getFullYear() - 1000)),
- gender: 'Male',
- likes: ['glasses', 'wine', 'the night']
- }
- ];
- mongoose.connect('mongodb://localhost/persons', function(err) {
- if (err) throw err;
- // create all of the dummy people
- async.each(data, function(item, cb) {
- Person.create(item, cb);
- }, function(err) {
- if (err) {
- // handle error
- }
- // run an aggregate query that will get all of the people who like a given
- // item. To see the full documentation on ways to use the aggregate
- // framework, see http://docs.mongodb.org/manual/core/aggregation/
- Person.aggregate(
- // select the fields we want to deal with
- {$project: {name: 1, likes: 1}},
- // unwind 'likes', which will create a document for each like
- {$unwind: '$likes'},
- // group everything by the like and then add each name with that like to
- // the set for the like
- {$group: {
- _id: {likes: '$likes'},
- likers: {$addToSet: '$name'}
- }},
- function(err, result) {
- if (err) throw err;
- console.log(result);
- /* [
- { _id: { likes: 'the night' }, likers: [ 'alucard' ] },
- { _id: { likes: 'wine' }, likers: [ 'alucard' ] },
- { _id: { likes: 'books' }, likers: [ 'lilly' ] },
- { _id: { likes: 'glasses' }, likers: [ 'alucard' ] },
- { _id: { likes: 'birds' }, likers: [ 'mary' ] },
- { _id: { likes: 'rabbits' }, likers: [ 'bob' ] },
- { _id: { likes: 'cats' }, likers: [ 'lilly', 'mary' ] },
- { _id: { likes: 'dogs' }, likers: [ 'lilly', 'bill' ] },
- { _id: { likes: 'tv' }, likers: [ 'bob' ] },
- { _id: { likes: 'games' }, likers: [ 'bob', 'bill' ] },
- { _id: { likes: 'movies' }, likers: [ 'mary', 'bill' ] }
- ] */
- cleanup();
- });
- });
- });
- function cleanup() {
- Person.remove(function() {
- mongoose.disconnect();
- });
- }
|