婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > express+mongoose實現對mongodb增刪改查操作詳解

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

熱門標簽:呼和浩特外呼系統原理是什么 小裙科技電銷機器人怎樣 內蒙古營銷智能外呼系統哪個好 青白江400企業電話申請 外呼線路資源屬于電信業務嗎 河南電話外呼系統招商 長沙電銷外呼防封卡是什么 crm外呼系統聯系方式 智能外呼系統官網

本文實例講述了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 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

每一段的作用看注釋即可?,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數據庫程序設計有所幫助。

您可能感興趣的文章:
  • MongoDB實現基于關鍵詞的文章檢索功能(C#版)
  • 深入了解MongoDB 分布式集群
  • 開源 5 款超好用的數據庫 GUI 帶你玩轉 MongoDB、Redis、SQL 數據庫(推薦)
  • JAVA代碼實現MongoDB動態條件之分頁查詢
  • MongoDB設計方法以及技巧示例詳解
  • MongoDB數據庫基礎操作總結
  • win7平臺快速安裝、啟動mongodb的方法
  • 使用Mongodb實現打卡簽到系統的實例代碼
  • 淺析MongoDB 全文檢索

標簽:黃石 菏澤 安順 池州 楚雄 白山 呼倫貝爾 舟山

巨人網絡通訊聲明:本文標題《express+mongoose實現對mongodb增刪改查操作詳解》,本文關鍵詞  express+mongoose,實現,對,mongodb,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《express+mongoose實現對mongodb增刪改查操作詳解》相關的同類信息!
  • 本頁收集關于express+mongoose實現對mongodb增刪改查操作詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    波多野结衣的一区二区三区| 91福利资源站| 成人小视频在线| 久久综合久久99| 免费一级片91| 26uuu国产电影一区二区| 免费高清在线一区| 欧美一二三在线| 久久精品国产免费看久久精品| 51午夜精品国产| 九色porny丨国产精品| 久久女同性恋中文字幕| 懂色一区二区三区免费观看| 国产精品国产自产拍在线| 色综合久久综合| 日韩二区三区四区| 久久久噜噜噜久噜久久综合| aa级大片欧美| 男男成人高潮片免费网站| 国产情人综合久久777777| 91视频精品在这里| 日日夜夜免费精品| 99久久久久免费精品国产| 亚洲视频免费在线观看| 欧美婷婷六月丁香综合色| 精品综合免费视频观看| 成人免费一区二区三区视频| 欧美少妇性性性| 国产在线播放一区| 亚洲精品你懂的| 日韩一区二区三区视频在线| 国产在线国偷精品免费看| 日本一区二区三区电影| 欧美色网站导航| 国产精品亚洲专一区二区三区| 自拍偷拍亚洲欧美日韩| 色域天天综合网| 久久成人免费日本黄色| 中文字幕在线播放不卡一区| 欧美一区日韩一区| 国模大尺度一区二区三区| 欧美国产成人精品| 日韩亚洲国产中文字幕欧美| 一本色道综合亚洲| 国产一区免费电影| 日韩电影一区二区三区| 亚洲日本免费电影| 国产日韩精品一区二区浪潮av| 欧美日韩成人激情| 色欧美日韩亚洲| 成人av综合一区| 国产馆精品极品| 国内外成人在线| 日本成人在线不卡视频| 亚洲男人的天堂网| 国产精品每日更新在线播放网址| 日韩一级大片在线| 制服丝袜激情欧洲亚洲| 欧美偷拍一区二区| 欧美日韩在线播放三区四区| 91免费视频大全| 91免费国产视频网站| 成人av集中营| 99久精品国产| 不卡的av在线播放| av中文字幕在线不卡| 波多野结衣的一区二区三区| 国产成人在线影院| 国产一区二区三区免费| 蜜芽一区二区三区| 午夜视频一区二区| 青青青伊人色综合久久| 日韩国产欧美在线视频| 日韩精品一级中文字幕精品视频免费观看 | 91精品国产福利在线观看| 在线一区二区三区做爰视频网站| 色一情一伦一子一伦一区| 91香蕉视频在线| 91久久线看在观草草青青| 91国产福利在线| 欧美日韩一区二区三区免费看| 91国内精品野花午夜精品| 欧美丰满一区二区免费视频| 欧美α欧美αv大片| 国产欧美久久久精品影院| 国产精品国产三级国产有无不卡| 综合av第一页| 秋霞午夜鲁丝一区二区老狼| 国产激情精品久久久第一区二区 | 午夜激情一区二区三区| 亚洲一区二区三区中文字幕| 午夜精品久久久久久久99水蜜桃| 五月天一区二区三区| 美女网站色91| 国产资源在线一区| 99re热视频精品| 欧美日韩国产另类不卡| 欧美成人女星排名| 国产精品高潮呻吟| 亚洲欧美偷拍三级| 日本美女一区二区三区视频| 国产成人丝袜美腿| 欧美视频一区二区| 粉嫩嫩av羞羞动漫久久久| av不卡一区二区三区| 欧美精品丝袜久久久中文字幕| 久久se精品一区二区| 成人av在线电影| 在线不卡a资源高清| 久久久久久久久久久久久女国产乱| 综合久久国产九一剧情麻豆| 久久国产三级精品| 欧美日韩一区成人| 中日韩av电影| 久久99国产精品尤物| 欧美体内she精视频| 中文字幕欧美激情一区| 久久国产视频网| 美女免费视频一区二区| 91丨九色丨蝌蚪丨老版| 555www色欧美视频| 亚洲精品五月天| 国产精品一区二区三区99| 欧美色图天堂网| 中文成人av在线| 久久成人免费电影| 欧美在线你懂得| 中文字幕在线一区| 国产在线精品免费av| 欧美疯狂性受xxxxx喷水图片| 日韩美女视频19| 国产成人欧美日韩在线电影| 欧美一区二区三区免费| 一区二区成人在线| 成人黄动漫网站免费app| 久久精品在线免费观看| 另类的小说在线视频另类成人小视频在线 | 欧美日韩亚洲综合一区| 中文字幕av一区二区三区免费看| 另类小说综合欧美亚洲| 欧美精品视频www在线观看| 亚洲黄色小视频| 国产成人精品影视| 久久国产夜色精品鲁鲁99| 色欧美日韩亚洲| 久久嫩草精品久久久精品| 午夜一区二区三区在线观看| aaa欧美色吧激情视频| 久久综合久久久久88| 美女网站在线免费欧美精品| 精品视频在线免费看| 亚洲视频精选在线| jvid福利写真一区二区三区| 欧美韩国日本一区| 成人网在线免费视频| 欧美国产日韩a欧美在线观看| 激情综合色播激情啊| 久久久蜜桃精品| 国产精品一区二区三区99| 国产女同互慰高潮91漫画| 精品sm在线观看| 男人的j进女人的j一区| 日韩一区二区视频| 免费成人av在线| 久久女同互慰一区二区三区| 久久国产精品第一页| 日韩亚洲欧美成人一区| 国产一区二区美女| 中文字幕亚洲成人| 欧美色图天堂网| 日韩中文字幕区一区有砖一区 | 日韩经典一区二区| 精品少妇一区二区| 国产乱妇无码大片在线观看| 国产精品久久久久aaaa樱花| eeuss鲁片一区二区三区在线看| 亚洲人成电影网站色mp4| 色欧美片视频在线观看在线视频| 午夜不卡在线视频| 91精彩视频在线| 偷偷要91色婷婷| 久久网站热最新地址| 91社区在线播放| 调教+趴+乳夹+国产+精品| 久久综合九色综合97婷婷| 国产成人丝袜美腿| 视频一区二区三区在线| 国产午夜三级一区二区三| 欧美又粗又大又爽| 国内成人免费视频| 夜夜嗨av一区二区三区| 26uuu亚洲综合色欧美| 91麻豆6部合集magnet| 26uuu亚洲综合色| 欧美伊人久久大香线蕉综合69| 精品一区二区三区视频| 亚洲综合免费观看高清完整版| 26uuu精品一区二区三区四区在线| 97精品电影院| 国产高清在线观看免费不卡|