本文實例講述了express+mongoose實現(xiàn)對mongodb增刪改查操作。分享給大家供大家參考,具體如下:
項目地址:https://github.com/jrainlau/mongoose_crud
寫在開頭
本文主要分享我如何使用express+mongoose對mongodb實現(xiàn)增刪改查操作,感謝cnode社區(qū)所有精品文章的幫助,以及@airuikun的開源項目airuikun/mongoose_crud對我的啟發(fā)。
學習nodejs已經(jīng)小半個月了,一直琢磨著做一些什么東西出來。由于有著一定的PHP經(jīng)驗,所以對數(shù)據(jù)庫的操作比較感興趣。乘著學習nodejs的勢頭,就打算把mongodb也一并學了。mongodb給我的感覺會比MySQL靈活一點,也比較好上手。掌握了一定的mongodb知識以后,便開始著手開發(fā),實現(xiàn)最基礎(chǔ)的增刪改查功能。
項目準備
首先你需要掌握一定的nodejs,express以及mongodb的知識,并且已經(jīng)安裝好express和mongoose模塊,同時電腦安裝有mongodb。關(guān)于mongodb的問題,可以移步我的另一篇文章:win7下快速啟動mongodb的方法,里面有詳細的安裝及配置過程。同時推薦使用robomongo作為mongodb的可視化操作工具,方便我們直接查看和操作數(shù)據(jù)庫。
項目開始
打開命令行,輸入
express -e mongoose_crud
“-e”表示使用ejs作為模版引擎(jade太丑不喜歡)。生成項目文件結(jié)構(gòu)以后,執(zhí)行
cd mongoose_crud npm install
安裝依賴包。
現(xiàn)在我們的項目應(yīng)該長這樣的(modules文件夾是我自己建的,后面會講到):
為了方便接下來的操作,推薦使用supervisor
來啟動項目
npm install supervisor -g
進入我們的項目文件夾,我們改寫一下package.json
文件,把里面的"scripts"改為下面的寫法
"scripts": {
"start": "supervisor ./bin/www"
},
以后要啟動項目只需要在項目文件夾下,執(zhí)行npm start
即可。
改寫文件
由于express自己生成的文件結(jié)構(gòu)不那么優(yōu)美,所以稍微修改一下,方便接下來的工作。
首先打開\route
文件夾,刪除沒用的user.js
,打開index.js
,修改為下面的內(nèi)容:
'use strict'
const routes = (app) => {
app.get('/', (req, res, next) => {
res.render('index', { title: 'Jrain真的很帥'})
})
}
然后打開app.js
文件夾,修改為以下內(nèi)容:
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,接下來就到真正的開發(fā)啦!
增刪改查功能實現(xiàn)
在根目錄下,新建一個modules
文件夾,里面新建一個叫做my_class.js
的文件。我們這個項目是建立一個班級學生管理系統(tǒng),能夠?qū)W生的姓名及學號進行增刪改查的操作。文件內(nèi)容如下:
'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連接成功!!')
})
// 創(chuàng)建schema
const classSchema = new mongoose.Schema({
name: String,
studentId: Number
})
// 創(chuàng)建model
const classModel = mongoose.model('newClass', classSchema) // newClass為創(chuàng)建或選中的集合
module.exports = classModel
每一段的作用看注釋即可?,F(xiàn)在我們已經(jīng)把項目跟mongodb連接好了,可以進行接下來的步驟。
我們會有5個頁面,分別是首頁,學生信息增加頁面,學生刪除頁面,學生修改頁面,學生查找頁面。在\views
文件夾內(nèi)建立相應(yīng)的ejs文件即可,代碼就不貼了,可以直接到項目去看:
https://github.com/jrainlau/mongoose_crud/tree/master/views
然后我們回到\routes\index.js
,我們幾乎所有的邏輯都會在這里面進行。
把當中內(nèi)容修改為下面的代碼:
'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請求接收參數(shù),進行相應(yīng)的操作,實現(xiàn)增刪改查的功能。主要用到的API有如下幾個:
我們的項目已經(jīng)全部完成了,測試一下吧!
尾聲
這篇東西不是教程,僅作為自己學習的一個記錄。如果能夠?qū)λ擞杏镁妥詈美?,如果覺得我哪里說得不對也歡迎指正。謝謝大家~!
希望本文所述對大家MongoDB數(shù)據(jù)庫程序設(shè)計有所幫助。
您可能感興趣的文章:- MongoDB實現(xiàn)基于關(guān)鍵詞的文章檢索功能(C#版)
- 深入了解MongoDB 分布式集群
- 開源 5 款超好用的數(shù)據(jù)庫 GUI 帶你玩轉(zhuǎn) MongoDB、Redis、SQL 數(shù)據(jù)庫(推薦)
- JAVA代碼實現(xiàn)MongoDB動態(tài)條件之分頁查詢
- MongoDB設(shè)計方法以及技巧示例詳解
- MongoDB數(shù)據(jù)庫基礎(chǔ)操作總結(jié)
- win7平臺快速安裝、啟動mongodb的方法
- 使用Mongodb實現(xiàn)打卡簽到系統(tǒng)的實例代碼
- 淺析MongoDB 全文檢索