详解Nodejs基于mongoose模块的增删改查的操作
2016-12-21 14:38
841 查看
MongoDB
MongoDB是基于Javascript语言的数据库,存储格式是JSON,而Node也是基于JavaScript的环境(库),所以node和mongoDB的搭配能减少因为数据转换带来的时间空间开销。
Mongoose
是MongoDB的一个对象模型工具,它将数据库中的数据转换为JavaScript对象以供你在应用中使用,封装了MongoDB对文档的的一些增删改查等常用方法,让NodeJS操作Mongodb数据库变得更加灵活简单。
安装模块mongoose
npm install mongoose
[注意] mongoose模块依赖mongodb
npm常用命令
npm install <name> -g 将包安装到全局环境中 npm install <name> –-save 安装的同时,将信息写入package.json中,便于后期维护查看 npm remove <name>移除 npm update <name>更新 npm root -g 查看全局的包安装路径 npm -v 查看npm的版本
开启mongodb数据库
进入mongod所在目录 执行命令 ./mongod --dbpath=存放数据的位置
例1:./mongod --dbpath=../data/dbname
例2:./mongod --dbpath=../data/dbname --port 自定义端口号,默认27017(了解即可,不推荐使用,修改默认端口号后期维护麻烦)
插入数据
// 引入模块 var mongoose = require('mongoose'); // 连接数据库 var db = mongoose.createConnection('mongodb://127.0.0.1:27017/test'); // 设置数据类型 var monSchema = new mongooose.Schema({ name:{type:String,default:"username"}, age:{type:Number}, sex:{type:String} }); // 选择集合 var monModel = db.model('user',monSchema); // 数据集 var content = {name:"Nick",age:23,sex:'男'}; // 实例化对象并插入数据 var monInsert = new monModel(content); monInsert.save(function(err){ if(err){ console.log(err); }else{ console.log('成功插入数据'); } db.close(); });
删除数据
// 引入模块 var mongoose = require('mongoose'); // 连接数据库 var db = mongoose.createConnection('mongodb://127.0.0.1:27017/test'); // 设置数据类型 var monSchema = new mongooose.Schema({ name:{type:String,default:"name"}, age:{type:Number}, sex:{type:String} }); // 选择集合 var monModel = db.model('user',monSchema); // 要删除的条件 var del = {name:"Nick"}; monModel.remove(del,function(err,result){ if(err){ console.log(err); }else{ console.log("update"); } db.close(); });
修改数据
// 引入模块 var mongoose = require('mongoose'); // 连接数据库 var db = mongoose.createConnection('mongodb://127.0.0.1:27017/test'); // cosole.log(db); // 设置数据类型 var monSchema = new mongooose.Schema({ name:{type:String,default:"name"}, age:{type:Number}, sex:{type:String} }); // 选择集合 var monModel = db.model('user',monSchema); // 原数据字段值 var oldValue = {name:"Nick"}; // 单条件更新 var newData1 = {$set:{name:"内容"}}; // 多条件更新 var newData2 = {$set:{name:"内容",age:2}}; monModel.update(oldValue,newData,function(err,result){ if(err){ console.log(err); }else{ console.log("update"); } db.close(); });
查询数据
// 引入模块 var mongoose = require('mongoose'); // 连接数据库 var db = mongoose.createConnection('mongodb://127.0.0.1:27017/test'); // cosole.log(db); // 设置数据类型 var monSchema = new mongooose.Schema({ name:{type:String,default:"name"}, age:{type:Number}, sex:{type:String} }); // 选择集合 var monModel = db.model('user',monSchema); var content = {name:"姓名2"}; var field = {name:1,age:1,sex:1}; monModel.find(content,field,function(err,result){ if(err){ console.log(err); }else{ console.log(result); } db.close(); });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 基于mongoose 的增删改查操作
- Nodejs基于mongoose模块的增删改查
- iOS 数据库详解 sqlite实现增删改查操作
- Java+MyEclipse+Tomcat (六)详解Servlet和DAO数据库增删改查操作
- MyBatis第二讲学习笔记 ,使用MyBatis对表执行增删改查操作——基于注解的实现
- 散列表的C程序实现,基于数组实现可以实现增删改查操作,
- 详解nodejs 文本操作模块-fs模块(五)
- 详解Android中一些SQLite的增删改查操作
- node.js基于fs模块对系统文件及目录进行读写操作的方法详解
- nodeJs链接Mysql做增删改查的简单操作
- JAVAWEB开发之mybatis详解(一)——mybatis的入门(实现增删改查操作)、自定义别名、抽取代码块以及动态SQL的使用
- mongoose的增删改查操作
- 基于视图的增删改查操作(颠覆传统思维吧)
- PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】
- MySQL数据库的增删改查操作详解
- nodejs操作mysql实现增删改查的实例
- 在Node中基于Mongoose对MongoDB进行增删查改(CRUD)操作(一)
- JavaScript对数据表格的增删改查操作详解
- 详解nodejs 文本操作模块-fs模块(三)
- 详解nodejs 文本操作模块-fs模块(四)