您的当前位置:首页正文

node.js利用mongoose获取mongodb数据的格式化问题详解

来源:独旅网

说明

大家都知道在mongodb 中获取数据,不管使用回调函数还是Promise又或者generate 语法最后得到都是mongoose.Query对象,不能直接操作如同普通对象一样得到单行数据。还有就是时间格式化问题,见下面。

下面示例默认使用co 和 es6 */yield 语法,当然也可以使用async/await

1. 安装mongoose

$ npm install mongoose co moment --save

说明:

  • mongoose: mongodb 的nodejs 数据库驱动
  • co: 一个自动执行的generate函数容器
  • moment: 时间格式化
  • 2. 处理数据

    如下代码:

    // 省略链接数据库,详情见文档
    const mongoose = require('mongoose')
    const co = require('co')
    const Schema = mongoose.Schema
    const PersonSchema = new Schema({
     name: String,
     age: String,
     createAt: {
     type: Date,
     default: Date.now,
     get: v => moment(v).format('YYYY-MM-DD HH:mm')
     }
    })
    
    const PersonModel = mongoose.model('Person', PersonSchema) // 创建模型
    const Person = new PersonModel() // 创建文档对象
    co(function * () {
     let person = yield Person.findOne({name: 'zhengsan'})
     // 这里person 是一个mongoose.Query对象
     // 到这里一般直接使用person 就是一个对象能够获取{ name, type, createAt } 
     // 但是不能够操作这三个,除非单独一个一个复制到另外一个对象,问题就在这里?
    })()

    这里通过 Object.keys(person)可以得到如下数据:

    [ '$__', 'isNew', 'errors', '_doc', '$init' ]

    3. 得到普通对象

    通过查询mongoose 文档最后得到解决办法而且,可以轻松格式化哦:

    // 接上面代码
    let person = yield Person.findOne({name: 'zhangsan'})
    person = person.toJSON({getters: true})
    // 此时person对象对象
    // { name: 'zhengsan', age: 32, createAt: '2017-02-03 12:30' }

    总结

    显示全文