溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

node.js利用mongoose獲取mongodb數(shù)據(jù)的格式化問題詳解

發(fā)布時間:2020-09-23 14:44:45 來源:腳本之家 閱讀:139 作者:triste 欄目:web開發(fā)

說明

大家都知道在mongodb 中獲取數(shù)據(jù),不管使用回調函數(shù)還是Promise又或者generate 語法最后得到都是mongoose.Query對象,不能直接操作如同普通對象一樣得到單行數(shù)據(jù)。還有就是時間格式化問題,見下面。

下面示例默認使用co 和 es6 */yield 語法,當然也可以使用async/await

1. 安裝mongoose

$ npm install mongoose co moment --save

說明:

  • mongoose: mongodb 的nodejs 數(shù)據(jù)庫驅動
  • co: 一個自動執(zhí)行的generate函數(shù)容器
  • moment: 時間格式化

2. 處理數(shù)據(jù)

如下代碼:

// 省略鏈接數(shù)據(jù)庫,詳情見文檔
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) // 創(chuàng)建模型
const Person = new PersonModel() // 創(chuàng)建文檔對象
co(function * () {
 let person = yield Person.findOne({name: 'zhengsan'})
 // 這里person 是一個mongoose.Query對象
 // 到這里一般直接使用person 就是一個對象能夠獲取{ name, type, createAt } 
 // 但是不能夠操作這三個,除非單獨一個一個復制到另外一個對象,問題就在這里?
})()

這里通過 Object.keys(person)可以得到如下數(shù)據(jù):

[ '$__', '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' }

總結

以上就是這篇文章的全部內容,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI