MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

mongodb implementazione distinta() in Meteor sul server?

Ok, dopo aver esplorato il codice e aver realizzato che mongo lib contiene implementazioni native di tutti i metodi necessari, ho riutilizzato la soluzione aggregate() da https://github.com/meteor/meteor/pull/644

Le semplici modifiche e la traduzione in coffeescript forniscono il seguente snippet da inserire nel codice lato server:

path = __meteor_bootstrap__.require("path")
MongoDB = __meteor_bootstrap__.require("mongodb")
Future = __meteor_bootstrap__.require(path.join("fibers", "future"))

myCollection = new Meteor.Collection "my_collection"

#hacky distinct() definition from https://github.com/meteor/meteor/pull/644
myCollection.distinct = (key)->
  future = new Future
  @find()._mongo.db.createCollection(@_name,(err,collection)=>
    future.throw err if err
    collection.distinct(key, (err,result)=>
      future.throw(err) if err
      future.ret([true,result])
      )
    )
  result = future.wait()
  throw result[1] if !result[0]
  result[1]

Lo svantaggio è che devi definirlo per ogni nuova collezione, ma è abbastanza semplice da risolvere con un altro hack tramite _.extend o qualcosa del genere, suppongo...

PS Ora è anche un pacchetto intelligente:mrt add mongodb-aggregation