sql >> Databáze >  >> NoSQL >> MongoDB

Najít a vrátit první odpovídající vnořený dokument z pole (Meteor / Mongo)

Uživatelé Meteoru:v době psaní tohoto článku (verze 1.0.4.1) není agregace na klientovi podporována.

Chtěl jsem ponechat kód na klientovi a také jsem chtěl reaktivitu, takže zde je moje řešení:

db.projects

// simplified structure

{
      title: 'awebsite.com'
      company: 'a company'
      companyID: Random.id()
      category: 'website'
      starred: false
      tasks: [
          {
            completed: true
            name: 'task1'
            category: 'ideas'
            todos: [
              {todo: 'something', completed: false, todoID: Random.id()}
              {todo: 'something', completed: false, todoID: Random.id()}
              {todo: 'something', completed: false, todoID: Random.id()}
            ]
          }
          {
            completed: false
            name: 'task2'
            category: 'ideas'
            todos: [
              {todo: 'something', completed: false, todoID: Random.id()}
              {todo: 'something', completed: false, todoID: Random.id()}
              {todo: 'something', completed: false, todoID: Random.id()}
            ]
          }
        ]
    }

../projekty.káva

Meteor.subscribe 'projects'
Tasks = new (Mongo.Collection)(null)   //use (null) to create client-only collection

Template.projects.rendered = ->
  results = Projects.findOne { title: 'awebsite.com' },
    fields: tasks: 1

  _.each results.tasks, (task) ->
    Tasks.insert (task)

Template.projects.helpers
  currentTask: ->
    Tasks.findOne completed: false


  1. dědictví v databázi dokumentů?

  2. Spring Mongo DB @DBREF

  3. Aktualizujte více dokumentů poskytnutím dokumentů v těle, mongoose/mongodb

  4. Mohu určit, zda je řetězec MongoDB ObjectID?