写于 2016.04.05node
项目地址:github.com/jrainlau/mo…git
本文主要分享我如何使用express+mongoose对mongodb实现增删改查操做,感谢cnode社区全部精品文章的帮助,以及@airuikun的开源项目airuikun/mongoose_crud对个人启发。 学习nodejs已经小半个月了,一直琢磨着作一些什么东西出来。因为有着必定的PHP经验,因此对数据库的操做比较感兴趣。乘着学习nodejs的势头,就打算把mongodb也一并学了。mongodb给个人感受会比MySQL灵活一点,也比较好上手。掌握了必定的mongodb知识之后,便开始着手开发,实现最基础的增删改查功能。github
首先你须要掌握必定的nodejs,express以及mongodb的知识,而且已经安装好express和mongoose模块,同时电脑安装有mongodb。关于mongodb的问题,能够移步个人另外一篇文章:win7下快速启动mongodb的方法,里面有详细的安装及配置过程。同时推荐使用robomongo做为mongodb的可视化操做工具,方便咱们直接查看和操做数据库。mongodb
打开命令行,输入 express -e mongoose_crud
“-e”表示使用ejs做为模版引擎(jade太丑不喜欢)。生成项目文件结构之后,执行 cd mongoose_crud && npm install
安装依赖包。 如今咱们的项目应该长这样的(modules文件夹是我本身建的,后面会讲到):数据库
为了方便接下来的操做,推荐使用supervisor
来启动项目 npm install supervisor -g
进入咱们的项目文件夹,咱们改写一下package.json
文件,把里面的"scripts"改成下面的写法express
"scripts": {
"start": "supervisor ./bin/www"
},
复制代码
之后要启动项目只须要在项目文件夹下,执行npm start
便可。npm
因为express本身生成的文件结构不那么优美,因此稍微修改一下,方便接下来的工做。 首先打开\route
文件夹,删除没用的user.js
,打开index.js
,修改成下面的内容:json
'use strict'
const routes = (app) => {
app.get('/', (req, res, next) => {
res.render('index', { title: 'Jrain真的很帅'})
})
}
复制代码
而后打开app.js
文件夹,修改成如下内容:segmentfault
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 setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
// uncomment after placing your favicon in /public
app.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 handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handlers
// development error handler
// will print stacktrace
if (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 user
app.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')
// 链接mongodb
mongoose.connect('mongodb://localhost/test')
// 实例化链接对象
const db = mongoose.connection
db.on('error', console.error.bind(console, '链接错误:'))
db.once('open', (callback) => {
console.log('MongoDB链接成功!!')
})
// 建立schema
const classSchema = new mongoose.Schema({
name: String,
studentId: Number
})
// 建立model
const classModel = mongoose.model('newClass', classSchema) // newClass为建立或选中的集合
module.exports = classModel
复制代码
每一段的做用看注释便可。如今咱们已经把项目跟mongodb链接好了,能够进行接下来的步骤。 咱们会有5个页面,分别是首页,学生信息增长页面,学生删除页面,学生修改页面,学生查找页面。在\views
文件夹内创建相应的ejs文件便可,代码就不贴了,能够直接到项目去看: github.com/jrainlau/mo… 而后咱们回到\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='/'>添加成功,点击返回首页</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='/'>删除成功,点击返回首页</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='/'>修改为功,点击返回首页</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()
,做为删除学生信息用。咱们的项目已经所有完成了,测试一下吧!
这篇东西不是教程,仅做为本身学习的一个记录。若是可以对他人有用就最好啦,若是以为我哪里说得不对也欢迎指正。谢谢你们~!