安装使用Mongoose配合Node.js操作MongoDB的基础教程


Posted in Javascript onMarch 01, 2016

安装mongoose

使用express准备一个TestMongoDB项目,命令序列如下:

express TestMongoDB
cd TestMongoDB
npm install

执行完上面的命令后,使用下面的命令安装mongoose:

npm install mongoose --save

这个命令会安装mongoose并将其作为项目的依赖,而mongoose依赖的MongoDB driver以及regexp等等模块也会被自动安装。

实例

使用mongoose可以新建数据库、新建集合、对集合内的文档进行CRUD操作,在写代码时,可以对照着mongo shell验证结果是否符合预期。

在TestMongoDB下新建一个mongo.js文件,内容如下:

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/accounts');
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function() {
 console.log('mongoose opened!');
 var userSchema = new mongoose.Schema({
   name:{type: String, unique: true}, 
   password:String
  }, 
  {collection: "accounts"}
  );
 var User = mongoose.model('accounts', userSchema);

 User.findOne({name:"WangEr"}, function(err, doc){
  if(err) console.log(err);
  else console.log(doc.name + ", password - " + doc.password);
 });

 var lisi = new User({name:"LiSi", password:"123456"});
 lisi.save(function(err, doc){
  if(err)console.log(err);
  else console.log(doc.name + ' saved');
 }); 
});

上面的文件,直接执行“node mongo.js”命令即可查看效果。

要使用mongoose,先require,然后使用connect方法连接数据库。connect原型:

connect(uri, options, [callback])

uri的格式类似:“mongodb://user:pass@localhost:port/database”。

mongoose的connection对象定义了一些事件,比如connected、open、close、error等,我们可以监听这些事件。

在我们的示例代码里,我监听了open事件,在回调函数中,定义了Schema,调用mongoose.model来编译Schema得到Model对象。需要注意的是,定义Schema时指定的collection名字与mongoose.model的第一参数要保持一致。

拿到了Model对象,就可以执行增删改查等操作了。Model对象有find()、findOne()、update()、remove()等方法,和我们在mongo shell里的用法类似。这些方法都有一个可选的callback,当你提供这些callback时,执行的结果会通过这个callback返回给你。如果你不提供,这些方法会返回一个Query对象,你可以再通过Query组装新的选项,然后调用Query的exec(callback)来提交查询。

我在代码里查找WangEr的档案时用了callback,没用Query。

Model对象有个Model(doc)方法,用来构造一个文档(Document)。创建Lisi的文档时就是这种Document对象的save()方法可以将文档保存到数据库。
通过mongoose进行的基本操作:
1、增

var obj = new Movie();
obj.title = '标题一';
obj.content = '内容';
obj.save(function(err) {
  
});

2、删

Movie.remove({
  _id:id
},function (err) {
  
})

3、改

Movie.update({
  _id:id
},json,{},function (err) {
  
})

4、查

Movie.findOne({
  _id: id
}, function(err, obj) {
 
});
Movie.find({}).sort({_id: -1}).limit(3).exec(function(err, obj) {
 
})
Javascript 相关文章推荐
在JS中最常看到切最容易迷惑的语法(转)
Oct 29 Javascript
轻量级的原生js日历插件calendar.js使用指南
Apr 28 Javascript
理解JavaScript表单的基础知识
Jan 25 Javascript
纯js实现页面返回顶部的动画(超简单)
Aug 10 Javascript
深入理解requireJS-实现一个简单的模块加载器
Jan 15 Javascript
Vue全局分页组件的实现代码
Aug 10 Javascript
脚手架vue-cli工程webpack的作用和特点
Sep 29 Javascript
监听angularJs列表数据是否渲染完毕的方法示例
Nov 07 Javascript
详解小程序循环require之坑
Mar 08 Javascript
jQuery创建折叠式菜单
Jun 15 jQuery
JavaScript中变量提升机制示例详解
Dec 27 Javascript
JavaScript中常用的3种弹出提示框(alert、confirm、prompt)
Nov 10 Javascript
如何使用Bootstrap的modal组件自定义alert,confirm和modal对话框
Mar 01 #Javascript
JavaScript html5 canvas绘制时钟效果
Mar 01 #Javascript
javascript使用Promise对象实现异步编程
Mar 01 #Javascript
javascript html5实现表单验证
Mar 01 #Javascript
javascript中FOREACH数组方法使用示例
Mar 01 #Javascript
JS实现Select的option上下移动的方法
Mar 01 #Javascript
angular2使用简单介绍
Mar 01 #Javascript
You might like
PHP中的CMS的涵义
2007/03/11 PHP
php表单转换textarea换行符的方法
2010/09/10 PHP
详解php比较操作符的安全问题
2015/12/03 PHP
php使用json_decode后数字对象转换成了科学计数法的解决方法
2017/02/20 PHP
JavaScript+CSS实现的可折叠二级菜单实例
2016/02/29 Javascript
AngularJS 指令详细介绍
2016/07/27 Javascript
Ajax基础知识详解
2017/02/17 Javascript
详解JavaScript中的坐标和距离
2019/05/27 Javascript
JQuery表单元素取值赋值方法总结
2020/05/12 jQuery
JS实现躲避粒子小游戏
2020/06/18 Javascript
Vue 构造选项 - 进阶使用说明
2020/08/14 Javascript
Vue Object.defineProperty及ProxyVue实现双向数据绑定
2020/09/02 Javascript
vue中echarts的用法及与elementui-select的协同绑定操作
2020/11/17 Vue.js
[27:53]2014 DOTA2华西杯精英邀请赛 5 24 NewBee VS iG
2014/05/26 DOTA
python控制台显示时钟的示例
2014/02/24 Python
Python Tkinter GUI编程入门介绍
2015/03/10 Python
python函数局部变量用法实例分析
2015/08/04 Python
浅谈python中的占位符
2017/11/09 Python
python钉钉机器人运维脚本监控实例
2019/02/20 Python
Python3.5常见内置方法参数用法实例详解
2019/04/29 Python
django框架实现一次性上传多个文件功能示例【批量上传】
2019/06/19 Python
Python中的 is 和 == 以及字符串驻留机制详解
2019/06/28 Python
Ooni英国官网:披萨烤箱
2020/05/31 全球购物
linux面试题参考答案(7)
2014/07/24 面试题
简历自荐信
2013/12/02 职场文书
2014年公司迎新年活动方案
2014/02/24 职场文书
资助贫困学生倡议书
2014/05/16 职场文书
《中国梦我的梦》大学生演讲稿
2014/08/20 职场文书
考试保密承诺书
2014/08/30 职场文书
领导批评与自我批评范文
2014/10/16 职场文书
个人股份转让协议书范本
2014/10/26 职场文书
三十年同学聚会感言
2015/07/30 职场文书
Python使用sql语句对mysql数据库多条件模糊查询的思路详解
2021/04/12 Python
端午节将至,用Python爬取粽子数据并可视化,看看网友喜欢哪种粽子吧!
2021/06/11 Python
Java并发编程之详解CyclicBarrier线程同步
2021/06/23 Java/Android
Mysql如何实现不存在则插入,存在则更新
2022/03/25 MySQL