nodejs操作mongodb的填删改查模块的制作及引入实例


Posted in NodeJs onJanuary 02, 2018

安装相关模块

如果使用这个的话,你需要先自己安装一下他需要的模块,在根目录输入

npm install mongodb --save

进行模块安装,安装成功以后就可以进行以下的步骤。

文件的引入

以下是我书写的相关代码,放到你可以引用的相关目录,本人放到了express的根目录

function Mongo(options) {
 this.settings = {
  url: 'mongodb://localhost:27017/jk',
  MongoClient:require('mongodb').MongoClient,
  assert:require('assert')
 };
 for(let i in options){
  this.settings[i] = options[i];
 }
 this._run = function (fun) {
  let that = this;
  let settings = this.settings;
  this.settings.MongoClient.connect(this.settings.url, function (err, db) {
   settings.assert.equal(null, err);
   console.log("Connected correctly to server");
   fun(db, function () {
    db.close();
   });
  });
 };
 this.insert = function (collectionName, data, func) {
  //增加数据
  let insertDocuments = function (db, callback) {
   let collection = db.collection(collectionName);
   collection.insertMany([
    data
   ], function (err, result) {
    if (!err) {
     func(true);
    } else {
     func(false);
    }
    callback(result);
   });
  };
  this._run(insertDocuments);
 };
 this.update = function (collectionName, updateData, data, func) {
  //更新数据
  let updateDocument = function (db, callback) {
   let collection = db.collection(collectionName);
   collection.updateOne(updateData
    , {$set: data}, function (err, result) {
     if (!err) {
      func(true);
     } else {
      func(false);
     }
     callback(result);
    });
  };
  this._run(updateDocument);
 };
 this.delete = function (collectionName, data, func) {
  //删除数据
  let deleteDocument = function (db, callback) {
   let collection = db.collection(collectionName);
   collection.deleteOne(data, function (err, result) {
    if (!err) {
     func(true);
    } else {
     func(false);
    }
    callback(result);
   });
  };
  this._run(deleteDocument);
 };
 this.find = function (collectionName, data, func) {
  //查找数据
  let findDocuments = function (db, callback) {
   // Get the documents collection
   let collection = db.collection(collectionName);
   // Find some documents
   collection.find(data).toArray(function (err, docs) {
    if (!err) {
     func(true,docs);
    }
    else {
     func(false, err);
    }
    callback(docs);
   });
  };
  this._run(findDocuments);
 };
}
module.exports = Mongo;

我存入到了一个名字叫server.js的文件名内

使用

我们在需要使用页面先将模块引入,比如我在路由文件index.js里面引入:

const Server = require("../server.js");

然后需要实例化对象,如下:

let server = new Server();

如果需要配置相关信息,可以在实例化的时候传入一个对象配置,可以配置数据库的地址:

let server = new Server({url:"mongodb://localhost:27017/mydb"});

里面封装了四个方法,添删改查,分别是

添加方法

server.insert(数据表名,需要插入的数据(键值对的对象),回调函数);

更新方法

server.update(数据表名,查询的数据(对象),更新的数据(对象),回调函数);

删除方法

server.delete(数据表名,查询的数据(对象),回调函数);

查找方法

server.find(数据表名,查询的数据(对象),回调函数);

回调函数都会返回两个值,第一个布尔类型,是否处理成功,第二个值,查找返回查找到的个数,别的都返回处理成功的个数(现在一次只处理一条)

使用案例

比如我需要在一个路由里面查找数据,我就需要这样:

server.find("users",{username:"username"},function (bool,data) {
  if(bool){
   console.log("查询到数据为"+data.length+"条");
  }
  else{
   console.log(data);
  }
 });
});

上面的代码是查询了users表里面username为username的字段的数据,如果成功,后面data就会返回一个数组,如果出现错误,就直接返回data错误。

以上这篇nodejs操作mongodb的填删改查模块的制作及引入实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
NodeJS url验证(url-valid)的使用方法
Nov 18 NodeJs
Nodejs+express+html5 实现拖拽上传
Aug 08 NodeJs
Nodejs如何复制文件
Mar 09 NodeJs
浅谈Nodejs应用主文件index.js
Aug 28 NodeJs
nodejs利用http模块实现银行卡所属银行查询和骚扰电话验证示例
Dec 30 NodeJs
nodeJs链接Mysql做增删改查的简单操作
Feb 04 NodeJs
nodejs学习笔记之路由
Mar 27 NodeJs
nodejs获取微信小程序带参数二维码实现代码
Apr 12 NodeJs
Express+Nodejs 下的登录拦截实现代码
Jul 01 NodeJs
Nodejs下使用gm圆形裁剪并合成图片的示例
Feb 22 NodeJs
webstorm中配置nodejs环境及npm的实例
May 15 NodeJs
nodejs实现套接字服务功能详解
Jun 21 NodeJs
nodejs实现OAuth2.0授权服务认证
Dec 27 #NodeJs
使用nodejs+express实现简单的文件上传功能
Dec 27 #NodeJs
nodejs超出最大的调用栈错误问题
Dec 27 #NodeJs
nodejs实现简单的gulp打包
Dec 21 #NodeJs
nodejs调取微信收货地址的方法
Dec 20 #NodeJs
基于nodejs实现微信支付功能
Dec 20 #NodeJs
nodeJS微信分享
Dec 20 #NodeJs
You might like
谈谈新手如何学习PHP
2006/12/23 PHP
php生成不重复随机数、数组的4种方法分享
2015/03/30 PHP
php htmlentities()函数的定义和用法
2016/05/13 PHP
yii2.0实现创建简单widgets示例
2016/07/18 PHP
PHP实现活动人选抽奖功能
2017/04/19 PHP
PHP基于SPL实现的迭代器模式示例
2018/04/22 PHP
改写一个简单的菜单 弹性大小
2010/12/02 Javascript
异步javascript的原理和实现技巧介绍
2012/11/08 Javascript
JavaScript控制浏览器全屏及各种浏览器全屏模式的方法、属性和事件
2015/12/20 Javascript
jquery动态创建div与input的实例代码
2016/10/12 Javascript
BootStrap实现响应式布局导航栏折叠隐藏效果(在小屏幕、手机屏幕浏览时自动折叠隐藏)
2016/11/30 Javascript
Javascript之面向对象--方法
2016/12/02 Javascript
基于Datatables跳转到指定页的简单实例
2017/11/09 Javascript
微信小程序自定义多选事件的实现代码
2018/05/17 Javascript
Vue登录注册并保持登录状态的方法
2018/08/17 Javascript
当vue路由变化时,改变导航栏的样式方法
2018/08/22 Javascript
TypeScript基础入门教程之三重斜线指令详解
2018/10/22 Javascript
JS多个异步请求 按顺序执行next实现解析
2019/09/16 Javascript
vue 实现setInterval 创建和销毁实例
2020/07/21 Javascript
python使用post提交数据到远程url的方法
2015/04/29 Python
python实现用户登陆邮件通知的方法
2015/07/09 Python
Python处理命令行参数模块optpars用法实例分析
2018/05/31 Python
使用python计算三角形的斜边例子
2020/04/15 Python
Python生成器next方法和send方法区别详解
2020/05/30 Python
阿根廷网上配眼镜:SmartBuyGlasses阿根廷
2016/08/19 全球购物
英国时尚服饰电商:Boohoo
2017/10/12 全球购物
 Alo Yoga官网:购买瑜伽服装
2018/06/17 全球购物
SIXPAD智能健身仪英国官网:革命性的训练装备品牌
2018/09/27 全球购物
华三通信H3C面试题
2015/05/15 面试题
实习教师自我鉴定
2013/12/09 职场文书
创新比赛获奖感言
2014/02/13 职场文书
《雾凇》教学反思
2014/02/17 职场文书
学校安全责任书范本
2014/07/23 职场文书
离婚协议书标准格式
2014/10/04 职场文书
Pytorch 如何实现LSTM时间序列预测
2021/05/17 Python
JavaScript执行机制详细介绍
2021/12/06 Javascript