express+mongoose实现对mongodb增删改查操作详解_MongoDB

来源:脚本之家  责任编辑:小易  

没听说过啊,表名叫什么都可以啊?不一定非要加s的吧。我怎么不加s也可以www.zgxue.com防采集请勿采集本网。

本文实例讲述了express+mongoose实现对mongodb增删改查操作。分享给大家供大家参考,具体如下:

举例说明:NJBlog后台采用Nodejs+express来提供Restful API,数据库采用 Mongodb,通过Mongoose驱动。NJBlog前台采用AngularJs进行开发。NJBlog目前所有前端JS代码全部采用模块化编写,使用

项目地址:https://github.com/jrainlau/mongoose_crud


写在开头

var mongoose=require(‘mongoose’);var PhotoList=mongoose.model(‘PhotoList’);module.exports=function(req,res,next){ PhotoList.find({},function(err,docs){ if(err){ res.end(‘Error’);return

本文主要分享我如何使用express+mongoose对mongodb实现增删改查操作,感谢cnode社区所有精品文章的帮助,以及@airuikun的开源项目airuikun/mongoose_crud对我的启发。

我们之后会使用 express 和 mongoose 两个著名 node 包。请确保你已经在系统上安装 npm 和 node 包管理器。Express 是 Node.js 中的一个「快速、强大而又轻量级」的网络框架,它可以轻松解决路由(Route)

学习nodejs已经小半个月了,一直琢磨着做一些什么东西出来。由于有着一定的PHP经验,所以对数据库的操作比较感兴趣。乘着学习nodejs的势头,就打算把mongodb也一并学了。mongodb给我的感觉会比MySQL灵活一点,也比较好上手。掌握了一定的mongodb知识以后,便开始着手开发,实现最基础的增删改查功能。


项目准备

NPM start 需要在package.json中定义,运行命令需要在nodejs环境下运行。E:\\workSpace\\nodejs\\helloworld>npm start helloworld@0.0.0 start E:\\workSpace\\nodejs\\helloworld node./bin/www GET/

首先你需要掌握一定的nodejs,express以及mongodb的知识,并且已经安装好express和mongoose模块,同时电脑安装有mongodb。关于mongodb的问题,可以移步我的另一篇文章:win7下快速启动mongodb的方法,里面有详细的安装及配置过程。同时推荐使用robomongo作为mongodb的可视化操作工具,方便我们直接查看和操作数据库。

项目开始

router.get('/list',function(req,res){ userInfo.find(function(err,docs){ if(err){ console.error(err);return;} res.render('list',{ title:'Express', data:docs });});});

打开命令行,输入

express -e mongoose_crud

“-e”表示使用ejs作为模版引擎(jade太丑不喜欢)。生成项目文件结构以后,执行

cd mongoose_crud && npm install安装依赖包。

现在我们的项目应该长这样的(modules文件夹是我自己建的,后面会讲到):

为了方便接下来的操作,推荐使用supervisor来启动项目

npm install supervisor -g

进入我们的项目文件夹,我们改写一下package.json文件,把里面的"scripts"改为下面的写法

"scripts": { "start": "supervisor ./bin/www" },

以后要启动项目只需要在项目文件夹下,执行npm start即可。

改写文件

由于express自己生成的文件结构不那么优美,所以稍微修改一下,方便接下来的工作。

首先打开\route文件夹,删除没用的user.js,打开index.js,修改为下面的内容:

'use strict'const routes = (app) => { app.get('/', (req, res, next) => { res.render('index', { title: 'Jrain真的很帅'}) })}

然后打开app.js文件夹,修改为以下内容:

var express = require('express');var path = require('path');var favicon = require('serve-favicon');var logger = require('morgan');var cookieParser = require('cookie-parser');var bodyParser = require('body-parser');var routes = require('./routes/index');var app = express();// view engine setupapp.set('views', path.join(__dirname, 'views'));app.set('view engine', 'ejs');// uncomment after placing your favicon in /publicapp.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));app.use(logger('dev'));app.use(bodyParser.json());app.use(bodyParser.urlencoded({ extended: false }));app.use(cookieParser());app.use(express.static(path.join(__dirname, 'public')));routes(app)// catch 404 and forward to error handlerapp.use(function(req, res, next) { var err = new Error('Not Found'); err.status = 404; next(err);});// error handlers// development error handler// will print stacktraceif (app.get('env') === 'development') { app.use(function(err, req, res, next) { res.status(err.status || 500); res.render('error', { message: err.message, error: err }); });}// production error handler// no stacktraces leaked to userapp.use(function(err, req, res, next) { res.status(err.status || 500); res.render('error', { message: err.message, error: {} });});module.exports = app;

其实就是把路由管理从app.js迁移到了\routes\index.js,方便我们管理。

我们可以测试一下,在浏览器输入localhost:3000,如果输出不是“Jrain真的很帅”,那就是你的项目出了问题。OK,接下来就到真正的开发啦!

增删改查功能实现

在根目录下,新建一个modules文件夹,里面新建一个叫做my_class.js的文件。我们这个项目是建立一个班级学生管理系统,能够对学生的姓名及学号进行增删改查的操作。文件内容如下:

'use strict'const mongoose = require('mongoose')// 连接mongodbmongoose.connect('mongodb://localhost/test')// 实例化连接对象const db = mongoose.connectiondb.on('error', console.error.bind(console, '连接错误:'))db.once('open', (callback) => { console.log('MongoDB连接成功!!')})// 创建schemaconst classSchema = new mongoose.Schema({ name: String, studentId: Number})// 创建modelconst classModel = mongoose.model('newClass', classSchema) // newClass为创建或选中的集合module.exports = classModel

每一段的作用看注释即可。现在我们已经把项目跟mongodb连接好了,可以进行接下来的步骤。

我们会有5个页面,分别是首页,学生信息增加页面,学生删除页面,学生修改页面,学生查找页面。在\views文件夹内建立相应的ejs文件即可,代码就不贴了,可以直接到项目去看:

https://github.com/jrainlau/mongoose_crud/tree/master/views

然后我们回到\routes\index.js,我们几乎所有的逻辑都会在这里面进行。

把当中内容修改为下面的代码:

'use strict'const classModel = require('../modules/my_class')const routes = (app) => { // 首页 app.get('/', (req, res, next) => { let response = res classModel.find({}, (err, result, res) => { if(err) return console.log(err) response.render('index', { result }) }) }) // 增加学生信息 app.get('/create', (req, res, next) => { res.render('create', {}) }) app.post('/create', (req, res, next) => { let newStudent = [{ name: req.body.name, studentId: req.body.student_id }] classModel.create(newStudent, (err) => { if(err) return console.log(err) res.send("<a href='http://www.zgxue.com/'>添加成功,点击返回首页</a>") }) }) // 删除学生信息 app.get('/del', (req, res, next) => { let response = res classModel.find({}, (err, result, res) => { if(err) return console.log(err) response.render('del', { result }) }) }) app.post('/del', (req, res, next) => { classModel.remove({_id: req.body.student}, (err, result) => { if(err) return console.log(err) console.log(result.result) res.send("<a href='http://www.zgxue.com/'>删除成功,点击返回首页</a>") }) }) // 修改学生信息 app.get('/update', (req, res, next) => { let response = res classModel.find({}, (err, result, res) => { if(err) return console.log(err) response.render('update', { result }) }) }) app.post('/update', (req, res, next) => { console.log(req.body) let num = req.body.num, condiction = {_id: req.body._id[num]}, query = {$set: {name: req.body.name[num], studentId: req.body.student_id[num]}} classModel.update(condiction, query, (err, result) => { if(err) { console.log(err) res.send('<script>alert("请勾选待修改的学生")</script>') } res.send("<a href='http://www.zgxue.com/'>修改成功,点击返回首页</a>") }) }) // 查找学生 app.get('/reach', (req, res, next) => { let result = null res.render('reach', { result }) }) app.post('/reach', (req, res, next) => { console.log(req.body) let response = res let reachType = req.body.reach_type, keyWord = req.body.keyword if (reachType == 0) { classModel.find({name: keyWord}, (err, result) => { if(err) return console.log(err) response.render('reach', { result }) }) } else { classModel.find({studentId: keyWord}, (err, result) => { if(err) return console.log(err) response.render('reach', { result }) }) } })}module.exports = routes

其原理是,程序通过post请求接收参数,进行相应的操作,实现增删改查的功能。主要用到的API有如下几个:

.find(),作为读取、查找学生信息用。

.create(),作为增加学生信息用。它是基于mongoose中的model的操作,传入一个json对象作为需要添加的内容,具体可自行查阅。

.update(),作为更新学生信息用。

.remove(),作为删除学生信息用。

我们的项目已经全部完成了,测试一下吧!

尾声

这篇东西不是教程,仅作为自己学习的一个记录。如果能够对他人有用就最好啦,如果觉得我哪里说得不对也欢迎指正。谢谢大家~!

希望本文所述对大家MongoDB数据库程序设计有所帮助。

几天改项目兼容的时候,后台改了js文件,自己检查了,感觉没有问题,前台jsp运行以后,发现问题还是存在,以为是自己写的不对,又改了几个版本,还是如此,后来问了有经验的同事,他让我清除浏览器缓存试试,清过之后,果然问题已经不存在了。几天改项目兼容的时候,后台改了js文件,自己检查了,感觉没有问题,前台jsp运行以后,发现问题还是存在,以为是自己写的不对,又改了几个版本,还是如此,后来问了有经验的同事,他让我清除浏览器缓存试试,清过之后,果然问题已经不存在了内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • express使用mongoose连接mongodb操作示例【附源码下载】
  • node+express+mongodb实现登录注册功能实例
  • 零基础搭建node.js、express、ejs、mongodb服务器及应用开发入门
  • vue+socket.io+express+mongodb 实现简易多房间在线群聊示例
  • express+vue+mongodb+session 实现注册登录功能
  • 如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
  • webpack4+express+mongodb+vue实现增删改查的示例
  • nodejs连接mongodb数据库实现增删改查
  • java连接mongodb进行增删改查的操作
  • mongodb增删改查详解_动力节点java学院整理
  • mongodb简单操作示例【连接、增删改查等】
  • node.js对mongodb进行增删改查操作的实例代码
  • mongodb 命令行下及php中insert数据详解
  • mongo中模糊查询的综合应用
  • mongodb聚合分组取第一条记录的案例与实现方法
  • mongodb与mysql常用操作语句对照
  • mongodb教程之基本管理命令
  • 解决mongodb 排序超过内存限制的问题
  • mongodb学习之text search文本搜索功能
  • mongodb如何对文档内数组进行过滤的方法步骤
  • 在 fedora 上安装 mongodb 服务器的方法教程
  • mongodb中文档的更新操作示例详解
  • nodejs+express+mongoose实现登录注册功能为什么能与数据库相连但是表单输入却没反应。后台也没有反应。
  • nodejs+express的mongoose连接数据库,为什么mongodb的表名一定要是复数的加s
  • node.js开发之express4.0使用mongoose连接mongodb表名必须为复数吗
  • 请教一个问题,express框架里边,next是什么意思
  • 使用express还有使用angularjs的必要吗
  • nodejs + express怎么实现Ajax方式及其简单功能
  • 如何在 Swift 中使用 Alamofire 进行网络编程
  • 为什么npm start启动不了服务器
  • Mongoose中model.find的查询结果怎么给视图使用
  • 如何管理 mongodb 导入json数据
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mongodbexpress使用mongoose连接mongodb操作示例【附源码下载】node+express+mongodb实现登录注册功能实例零基础搭建node.js、express、ejs、mongodb服务器及应用开发入门vue+socket.io+express+mongodb 实现简易多房间在线群聊示例express+vue+mongodb+session 实现注册登录功能如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目webpack4+express+mongodb+vue实现增删改查的示例nodejs连接mongodb数据库实现增删改查java连接mongodb进行增删改查的操作mongodb增删改查详解_动力节点java学院整理mongodb简单操作示例【连接、增删改查等】node.js对mongodb进行增删改查操作的实例代码mongodb 命令行下及php中insert数据详解mongo中模糊查询的综合应用mongodb聚合分组取第一条记录的案例与实现方法mongodb与mysql常用操作语句对照mongodb教程之基本管理命令解决mongodb 排序超过内存限制的问题mongodb学习之text search文本搜索功能mongodb如何对文档内数组进行过滤的方法步骤在 fedora 上安装 mongodb 服务器的方法教程mongodb中文档的更新操作示例详解mongodb常用操作命令大全mongodb各种查询操作详解mongodb数据库插入、更新和删除操mongodb 数据库操作--备份 还原 mongodb插入数据的3种方法mongodb中使用distinct去重的简单mongodb整库备份与还原以及单个cmongodb查询操作限制返回字段的方mongodb 实现远程连接浅谈mysql和mariadb区别(mariadbmongodb exception: $concat only suppormongodb索引使用详解mongodb数据库入门之curd简单操作示例解决mongodb 排序超过内存限制的问题mongodb系列教程(一):nosql起源mongodb学习以及集群搭建的实践全纪录windows或linux系统中备份和恢复mongodb数mongodb的安装启动及做成windows服务的教mongodb教程之数据操作实例sqlserver与mongodb结合使用nhibernate
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved