亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

express+mongoose實現對mongodb增刪改查操作詳解

2020-10-29 18:40:30
字體:
來源:轉載
供稿:網友

本文實例講述了express+mongoose實現對mongodb增刪改查操作。分享給大家供大家參考,具體如下:

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


寫在開頭

本文主要分享我如何使用express+mongoose對mongodb實現增刪改查操作,感謝cnode社區所有精品文章的幫助,以及@airuikun的開源項目airuikun/mongoose_crud對我的啟發。
學習nodejs已經小半個月了,一直琢磨著做一些什么東西出來。由于有著一定的PHP經驗,所以對數據庫的操作比較感興趣。乘著學習nodejs的勢頭,就打算把mongodb也一并學了。mongodb給我的感覺會比MySQL靈活一點,也比較好上手。掌握了一定的mongodb知識以后,便開始著手開發,實現最基礎的增刪改查功能。


項目準備

首先你需要掌握一定的nodejs,express以及mongodb的知識,并且已經安裝好express和mongoose模塊,同時電腦安裝有mongodb。關于mongodb的問題,可以移步我的另一篇文章:win7下快速啟動mongodb的方法,里面有詳細的安裝及配置過程。同時推薦使用robomongo作為mongodb的可視化操作工具,方便我們直接查看和操作數據庫。

項目開始

打開命令行,輸入
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

每一段的作用看注釋即可?,F在我們已經把項目跟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='/'>添加成功,點擊返回首頁</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(),作為刪除學生信息用。

我們的項目已經全部完成了,測試一下吧!

尾聲

這篇東西不是教程,僅作為自己學習的一個記錄。如果能夠對他人有用就最好啦,如果覺得我哪里說得不對也歡迎指正。謝謝大家~!

希望本文所述對大家MongoDB數據庫程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久青草精品视频免费观看| 97婷婷涩涩精品一区| 久久乐国产精品| 亚洲一区二区三区视频| 久久伊人精品视频| 亚洲大尺度美女在线| 日韩精品高清在线观看| 国产一区二区三区在线看| 欧美成人中文字幕| 国产精品久久久久久久app| 国产第一区电影| 亚洲jizzjizz日本少妇| 97视频免费在线看| 欧美激情在线有限公司| 国产精品69av| 日本久久久久久久| 九九热最新视频//这里只有精品| 91在线观看免费观看| 红桃av永久久久| 欧美精品18videos性欧| 欧美在线一区二区视频| 亚洲片在线资源| 国产区精品在线观看| 亚洲韩国青草视频| 日韩不卡在线观看| 中文字幕一区日韩电影| 日韩一中文字幕| 国产噜噜噜噜噜久久久久久久久| 国产福利精品在线| x99av成人免费| xxav国产精品美女主播| 欧洲午夜精品久久久| 久久精品成人欧美大片古装| 欧美—级a级欧美特级ar全黄| 国产精品自拍偷拍视频| 中文字幕不卡在线视频极品| 亚洲理论电影网| 国产精品极品尤物在线观看| 91免费福利视频| 国产精品久久久久久av福利软件| 一区二区三区精品99久久| 亚洲精品中文字| 欧洲成人在线观看| 国产精品福利在线观看| 国产亚洲一区二区精品| 国产精品高清在线观看| 久久精品99国产精品酒店日本| 国产在线日韩在线| 日韩在线一区二区三区免费视频| 18一19gay欧美视频网站| 国产精品男人的天堂| 欧美第一黄网免费网站| 亚洲第一精品电影| 91精品久久久久久久久久入口| 国产精品精品视频一区二区三区| 国外成人在线视频| 国产精品久久久久久亚洲影视| 国产a∨精品一区二区三区不卡| 成人激情电影一区二区| 丝袜亚洲欧美日韩综合| 伊人久久免费视频| 九九久久精品一区| 亚洲精品午夜精品| 国产suv精品一区二区三区88区| 久久99国产精品自在自在app| 日韩人在线观看| 欧美激情一区二区三区在线视频观看| 久久久999精品| 亚洲级视频在线观看免费1级| 日韩亚洲一区二区| 日韩精品在线影院| 国产精品视频精品| 午夜精品一区二区三区在线| 日韩成人中文字幕在线观看| 久久久久久久久久久亚洲| 91社区国产高清| 国外成人在线播放| 久久久国产91| 国产亚洲精品久久久久久牛牛| 欧美久久精品一级黑人c片| 国产精品人成电影在线观看| 亚洲最大福利视频网站| 中文精品99久久国产香蕉| 富二代精品短视频| 欧美性高跟鞋xxxxhd| 懂色aⅴ精品一区二区三区蜜月| 国产97在线视频| 亚洲一二三在线| 欧美日韩国内自拍| 奇米成人av国产一区二区三区| 国产suv精品一区二区| 欧美高清无遮挡| 久久露脸国产精品| xxxx性欧美| 日韩成人在线视频| 日韩中文字幕免费视频| 91亚洲精品一区| 国产精品视频永久免费播放| 亚洲九九九在线观看| 尤物yw午夜国产精品视频明星| 日产日韩在线亚洲欧美| 免费91在线视频| 最近2019中文免费高清视频观看www99| 国产成一区二区| 国产一区二区三区在线观看网站| 午夜伦理精品一区| 久久琪琪电影院| 国产91色在线播放| 亚洲韩国青草视频| 亚洲免费电影在线观看| 欧美一级高清免费| 亚洲免费人成在线视频观看| 国产99视频在线观看| 亚洲福利视频网| 91超碰caoporn97人人| 亚洲成人激情小说| 亚洲精品www久久久| 国产亚洲精品va在线观看| 91国产一区在线| 久久久噜久噜久久综合| 日韩成人在线视频网站| 国模极品一区二区三区| 伊人久久免费视频| 亚洲自拍中文字幕| 国产欧美日韩中文| 亚洲第一福利视频| 色噜噜久久综合伊人一本| 成人在线观看视频网站| 国产欧美久久一区二区| 孩xxxx性bbbb欧美| 亚洲女人被黑人巨大进入al| 另类图片亚洲另类| 日韩av中文字幕在线免费观看| 久久久久久久激情视频| 久久久视频在线| 久久精品国产91精品亚洲| 九九视频直播综合网| 中文字幕久热精品视频在线| 欧美精品福利视频| 91超碰中文字幕久久精品| 国产视频观看一区| 亚洲男女性事视频| 亚洲精品视频在线观看视频| 5566日本婷婷色中文字幕97| 一本一本久久a久久精品综合小说| 国产亚洲精品美女久久久| 91精品国产乱码久久久久久久久| 亚洲美女性生活视频| 成人免费视频网址| 欧美激情手机在线视频| 欧美另类高清videos| 色噜噜久久综合伊人一本| 久久天天躁狠狠躁老女人| 国产亚洲精品美女久久久| 欧美色播在线播放| 欧美尺度大的性做爰视频| 国产精品高精视频免费| 国产精品久久久久91| 久热精品视频在线| 国产精品久久久久一区二区| 国产脚交av在线一区二区| 美女性感视频久久久| 精品国产91久久久久久老师| 国产精品自产拍在线观|