node使用Mongoose类库实现简单的增删改查


Posted in Javascript onNovember 08, 2018

Mongoose是在nodejs环境中对MongoDB数据库操作的封装,一种对象模型工具,可以将数据库中的数据转换为javascript对象供我们使用。

Mongoose安装

npm install mongoose

安装成功后,我们就可以使用 require('mongoose')来使用了;

下面是链接本地数据库 mongoosedb,代码如下:

var mongoose = require('mongoose');
var DB_URL = 'mongodb://localhost:27017/dataDb';

/* 链接 */
mongoose.connect(DB_URL);

/* 链接成功 */
mongoose.connection.on('connected', function() {
 console.log('Mongoose connection open to ' + DB_URL);
});

// 链接异常
mongoose.connection.on('error', function(err) {
 console.log('Mongoose connection error:' + err);
});

// 链接断开

mongoose.connection.on('disconnected', function() {
 console.log('Mongoose connection disconnected');
});

如下图所示

node使用Mongoose类库实现简单的增删改查

从如上代码,监听了几个事件,并且执行触发了connected事件,这表示连接成功。

2. Schema介绍

它是一种以文件形式存储的数据库模型骨架,不具备对数据库操作的能力,仅仅只是数据库在程序片段中的一种表现,可以理解为表结构。

那么如何去定义一个Schema呢?请看如下代码:

var mongoose = require('mongoose');
var TestSchema = new mongoose.Schema({
 name: { type: String }, // 属性name,类型为String
 age: { type: Number, default: 30 }, // 属性age,类型为Number,默认值为30
 time: { type: Date, default: '当前时间' }
});

如上在我们的TestSchema中每个key在我们的文件将被转换为相关的SchemaType定义的一个属性。允许使用的SchemaTypes有如下类型:

  • String
  • Number
  • Date
  • Buffer
  • Boolean
  • Mixed
  • ObjectId
  • Array

如果我们在如上编写完成后,我们需要添加额外的键的话,我们可以使用Schema中的add方法.

3. 创建一个模型

我们上面定义了Schema,我们需要将我们的TestSchema转成我们可以使用的模型,模型具有对数据库操作的能力。
我们可以通过 mongoose.model(modelName, schema);

先来结合schema和创建一个模型来简单的看一个demo,如下代码:

var mongoose = require('mongoose');
// schema定义
var TestSchema = new mongoose.Schema({
 name: { type: String },
 age: { type: String },
 sex: { type: String }
});

// 创建model
var TestModel = mongoose.model('test1', TestSchema);

// 初始化数据 
var TestInt = new TestModel({
 name: 'kongzhi',
 age: '30',
 sex: 'girl'
});

console.log(TestInt.name); // kongzhi
console.log(TestInt.age); // 30
console.log(TestInt.sex); // girl

下面我们来简单的使用上面定义的内容,来做个简单的数据库增删改查的操作。

1. 在项目中的根目录下新建一个db.js, 代码如下:

var mongoose = require('mongoose');
var DB_URL = 'mongodb://localhost:27017/dataDb';

/* 链接 */
mongoose.connect(DB_URL);

/* 链接成功 */
mongoose.connection.on('connected', function() {
 console.log('Mongoose connection open to ' + DB_URL);
});

// 链接异常
mongoose.connection.on('error', function(err) {
 console.log('Mongoose connection error:' + err);
});

// 链接断开

mongoose.connection.on('disconnected', function() {
 console.log('Mongoose connection disconnected');
});

module.exports = mongoose;

2. 下面我们新建一个user的Schema,命名为user.js, 它有如下属性,如下代码:

/*
 定义一个user的Schema
*/
var mongoose = require('./db.js');
var Schema = mongoose.Schema;

var UserSchema = new Schema({
 username: { type: String }, // 用户名
 password: { type: String }, // 密码
 age: { type: Number }, // 年龄
});

/* model 是由schema生成的模型,具有对数据库操作的能力 */

module.exports = mongoose.model('User', UserSchema);

3. 数据库操作,我们新建一个文件叫 app.js

3.1 插入数据(Model.save([fn])),代码如下:

var User = require('./user.js');
// 插入数据

var user = new User({
 username: 'kongzhi0707',
 password: '123456',
 age: 30
});

user.save(function(err, res) {
 if (err) {
  console.log(err);
 } else {
  console.log(res);
 }
});

然后在命令行中运行app.js ,可以看到如下:

node使用Mongoose类库实现简单的增删改查

然后我们再到本地数据库中查看数据,可以看到新增一条数据,如下图所示

node使用Mongoose类库实现简单的增删改查

从数据库中可以看到插入数据成功了;

3.2 更新数据(Model.update(conditions, doc, [options], [callback]))

conditions: 更新的条件,该值是一个对象。
doc: 需要更新的内容,该值也是一个对象。
options: 可选参数,它有如下属性:
safe :(布尔型)安全模式(默认为架构中设置的值(true))
upsert :(boolean)如果不匹配,是否创建文档(false)
multi :(boolean)是否应该更新多个文档(false)
runValidators:如果为true,则在此命令上运行更新验证程序。更新验证器根据模型的模式验证更新操作。
strict:(布尔)覆盖strict此更新的选项
overwrite: (布尔)禁用只更新模式,允许您覆盖文档(false)
callback: 回调函数

如下代码执行更新:

var User = require('./user.js');

// 更新数据 

function update() {
 // 更新数据的条件查询
 var wherestr = {'username': 'kongzhi0707'};

 // 执行更新数据
 var updatestr = {'password': 'abcdef'};

 User.update(wherestr, updatestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 调用更新函数
update();

运行app.js 后,如下图所示:

node使用Mongoose类库实现简单的增删改查

继续查看数据库,可以看到password字段被更新了,如下图所示:

node使用Mongoose类库实现简单的增删改查

3.3 findByIdAndUpdate(id, [update], [options], [callback]);

根据id进行更新;此id就是数据库中自动生成的id;如下代码,

var User = require('./user.js');

// 更新数据 

function update() {
 // 更新数据的条件查询
 var id = '5b3a4941ca11752732fee772';

 // 执行更新数据
 var updatestr = {'password': 'vvvvv'};

 User.findByIdAndUpdate(id, updatestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 调用更新函数
update();

如下图数据库显示如下:

node使用Mongoose类库实现简单的增删改查

3.4 删除 Model.remove(conditions, [callback])

代码如下:

var User = require('./user.js');

function del() {
 // 删除数据的条件
 var wherestr = {'username': 'kongzhi0707'};

 User.remove(wherestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 调用函数
del();

到数据库中查看数据,可以看到没有这条数据了;

3.5 条件查询 Model.find(conditions, [fields], [options], [callback]);

如下代码所示:

var User = require('./user.js');
function find() {
 // 删除数据的条件
 var wherestr = {'userName': '龙恩0707'};

 User.find(wherestr, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res);
  }
 });
}
// 调用函数
find();

执行后,如下所示:

node使用Mongoose类库实现简单的增删改查

3.6 数量查询 Model.count(conditions, [callback])

var User = require('./user.js');

function getCountByConditions() {

 User.count({}, function(err, res) {
  if (err) {
   console.log(err);
  } else {
   console.log(res); // 会输出数据库数据的数量
  }
 });
}
// 调用函数
getCountByConditions();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 数组循环引起的思考
Jan 01 Javascript
js调用activeX获取u盘序列号的代码
Nov 21 Javascript
编写js扩展方法判断一个数组中是否包含某个元素
Nov 08 Javascript
jquery的each方法使用示例分享
Mar 25 Javascript
JavaScript把数组作为堆栈使用的方法
Mar 20 Javascript
jquery自适应布局的简单实例
May 28 Javascript
Angular的Bootstrap(引导)和Compiler(编译)机制
Jun 20 Javascript
D3.js实现直方图的方法详解
Sep 25 Javascript
JavaScript中splice与slice的区别
May 09 Javascript
详解vue过滤器在v2.0版本用法
Jun 01 Javascript
Angular自定义组件实现数据双向数据绑定的实例
Dec 11 Javascript
jQuery+Ajax+js实现请求json格式数据并渲染到html页面操作示例
Jun 02 jQuery
webpack4+express+mongodb+vue实现增删改查的示例
Nov 08 #Javascript
Echarts之悬浮框中的数据排序问题
Nov 08 #Javascript
Jquery和CSS实现选择框重置按钮功能
Nov 08 #jQuery
基于React Native 0.52实现轮播图效果
Aug 25 #Javascript
详解webpack打包后如何调试的方法步骤
Nov 07 #Javascript
微信小程序列表中item左滑删除功能
Nov 07 #Javascript
Angular 实现输入框中显示文章标签的实例代码
Nov 07 #Javascript
You might like
求PHP数组最大值,最小值的代码
2011/10/31 PHP
如何简单地用YUI做JavaScript动画
2007/03/10 Javascript
JS DOM 操作实现代码
2010/08/01 Javascript
jquery中使用ajax获取远程页面信息
2011/11/13 Javascript
微信小程序 开发工具快捷键整理
2016/10/31 Javascript
jQuery插件FusionCharts绘制的2D条状图效果【附demo源码】
2017/05/13 jQuery
node.js连接MongoDB数据库的2种方法教程
2017/05/17 Javascript
Javascript别踩白块儿(钢琴块儿)小游戏实现代码
2017/07/20 Javascript
基于vue2实现上拉加载功能
2017/11/28 Javascript
JS实现判断图片是否加载完成的方法分析
2018/07/31 Javascript
axios 封装上传文件的请求方法
2018/09/26 Javascript
Vue实现鼠标经过文字显示悬浮框效果的示例代码
2020/10/14 Javascript
[01:05:12]2014 DOTA2国际邀请赛中国区预选赛 TongFu VS CIS-GAME
2014/05/21 DOTA
Python ZipFile模块详解
2013/11/01 Python
python web基础之加载静态文件实例
2018/03/20 Python
python实现换位加密算法的示例
2018/10/14 Python
Python写一个基于MD5的文件监听程序
2019/03/11 Python
python装饰器常见使用方法分析
2019/06/26 Python
Django的models模型的具体使用
2019/07/15 Python
用Python将Excel数据导入到SQL Server的例子
2019/08/24 Python
python 负数取模运算实例
2020/06/03 Python
详解HTML5中的picture元素响应式处理图片
2018/01/03 HTML / CSS
丽笙酒店官方网站:Radisson Hotels
2019/05/07 全球购物
银行演讲稿范文
2014/01/03 职场文书
蔬菜基地的创业计划书
2014/01/06 职场文书
展会邀请函范文
2014/01/26 职场文书
绿色学校实施方案
2014/03/31 职场文书
财务管理专业自荐书
2014/09/02 职场文书
大学生推广普通话演讲稿
2014/09/21 职场文书
幼儿园新学期开学寄语
2015/05/27 职场文书
活动宣传稿范文
2015/07/23 职场文书
2016年综治和平安建设宣传月活动总结
2016/04/01 职场文书
SpringBoot整合MongoDB的实现步骤
2021/06/23 MongoDB
javascript条件式访问属性和箭头函数介绍
2021/11/17 Javascript
python入门学习关于for else的特殊特性讲解
2021/11/20 Python
Nginx如何获取自定义请求header头和URL参数详解
2022/07/23 Servers