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


Posted in Javascript onOctober 06, 2017

说明

大家都知道在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' }

总结

以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
jquery提升性能最佳实践小结
Dec 06 Javascript
关于jquery append() html时的小问题的解决方法
Dec 16 Javascript
JavaScript动态插入script的基本思路及实现函数
Nov 11 Javascript
jquery中html、val与text三者属性取值的联系与区别介绍
Dec 29 Javascript
IE浏览器不支持getElementsByClassName的解决方法
Aug 27 Javascript
js判断浏览器版本以及浏览器内核的方法
Jan 20 Javascript
jquery+css实现的红色线条横向二级菜单效果
Aug 22 Javascript
下一代Bootstrap的5个特点 超酷炫!
Jun 17 Javascript
js实现砖头在页面拖拉效果
Nov 20 Javascript
js中getter和setter用法实例分析
Aug 14 Javascript
Vue实现类似Spring官网图片滑动效果方法
Mar 01 Javascript
JavaScript判断浏览器版本的方法
Nov 03 Javascript
node.js中http模块和url模块的简单介绍
Oct 06 #Javascript
你应该知道的几类npm依赖包管理详解
Oct 06 #Javascript
vue-cli构建项目使用 less的方法
Oct 04 #Javascript
浅谈Angular2 模块懒加载的方法
Oct 04 #Javascript
浅谈angular2路由预加载策略
Oct 04 #Javascript
浅谈Angular路由复用策略
Oct 04 #Javascript
React-Native之定时器Timer的实现代码
Oct 04 #Javascript
You might like
PHP 数据库树的遍历方法
2009/02/06 PHP
php提示Call-time pass-by-reference has been deprecated in的解决方法[已测]
2012/05/06 PHP
DOM XPATH获取img src值的query
2013/09/23 PHP
php和editplus正则表达式去除空白行
2015/04/17 PHP
laravel框架数据库配置及操作数据库示例
2019/10/10 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
用jquery实现下拉菜单效果的代码
2010/07/25 Javascript
extjs中grid中嵌入动态combobox的应用
2011/01/01 Javascript
jquery 插件学习(五)
2012/08/06 Javascript
jquery Mobile入门—外部链接切换示例代码
2013/01/08 Javascript
js中return false(阻止)的用法
2013/08/14 Javascript
jquery实现的网页自动播放声音
2014/04/30 Javascript
JavaScript实现Flash炫光波动特效
2015/05/14 Javascript
jQuery实现首页图片淡入淡出效果的方法
2015/06/10 Javascript
react-native 封装选择弹出框示例(试用ios&android)
2017/07/11 Javascript
Vue 多层组件嵌套二种实现方式(测试实例)
2017/09/08 Javascript
使用JS实现气泡跟随鼠标移动的动画效果
2017/09/16 Javascript
详解vue中引入stylus及报错解决方法
2017/09/22 Javascript
vue-cli构建vue项目的步骤详解
2019/01/27 Javascript
JavaScript获取当前url路径过程解析
2019/12/27 Javascript
JS如何操作DOM基于表格动态展示数据
2020/10/15 Javascript
python代码检查工具pylint 让你的python更规范
2012/09/05 Python
Python处理json字符串转化为字典的简单实现
2016/07/07 Python
使用python os模块复制文件到指定文件夹的方法
2019/08/22 Python
python微信公众号开发简单流程实现
2020/03/09 Python
使用CSS3实现多列布局与多背景的技巧
2016/02/29 HTML / CSS
美国领先的礼品卡网站:GiftCards.com
2016/11/02 全球购物
餐厅总经理岗位职责
2013/12/31 职场文书
乡镇机关党员民主评议表自我评价
2014/09/21 职场文书
个人委托书如何写
2014/09/25 职场文书
微观世界观后感
2015/06/10 职场文书
某某店铺的开业庆典主持词范本
2019/11/25 职场文书
MySQL 数据类型选择原则
2021/05/27 MySQL
nginx刷新页面出现404解决方案(亲测有效)
2022/03/18 Servers
springboot应用服务启动事件的监听实现
2022/04/06 Java/Android
win10音频服务未响应怎么解决?win10音频服务未响应未修复的解决方法
2022/08/14 数码科技