在Node.js中操作Mongodb

3.0文檔:http://mongodb.github.io/node-mongodb-native/3.0/

1.引入依賴包:

npm install mongodb --save-dev

2.建立一個簡單的服務(wù),引入mongodb:
var express = require('express');

var app = express();

var MongoClient = require('mongodb').MongoClient;

var dbURL = 'mongodb://localhost:27017';

app.listen(process.env.POST || 8080);
3.寫個路由
app.get('/insert',function(req, res) {
    MongoClient.connect(dbURL,function(err, db) {

        assert.equal(err,null);
        const person = db.db('person');
        const student = person.collection('student');

        student.insertOne({

            "name": "insert in nodejs"

        },function(error, result) {
            var re = JSON.parse(result);
            if (re.n === 1) {
                res.send("插入成功。");
            } else {
                res.send("插入失敗,error:" + error);
            }
            res.end();
            db.close();
        })
    })
})

(1)連上數(shù)據(jù)庫:connect(dbURL,callback)
(2)獲取到要操作的數(shù)據(jù)庫,然后獲取要操作的表:

const person = db.db('person');
const student = person.collection('student');

舊版本的寫法是直接獲取person數(shù)據(jù)庫余赢,回調(diào)函數(shù)中的db為返回的person數(shù)據(jù)庫:

var dbURL = 'mongodb://localhost:27017/person';
var student = db.collection('student');

這樣寫在新版中會報錯: db.collection() is not a function.大概是廢除了揽惹。

在瀏覽器中訪問丰辣,然后用命令查看一下是否插入成功:

image.png
image.png
// 查
app.get('/query',function(req, res) {
    MongoClient.connect(dbURL,function(err, db) {
        assert.equal(err,null);
        
        const person = db.db('person');
        const student = person.collection('student');

        student.find({}).toArray(function(error, docs) {
            res.send(docs);         
            res.end();
            db.close();
        })
    })
})
// 改
app.get('/update',function(req, res) {
    MongoClient.connect(dbURL,function(err, db) {

        assert.equal(err,null);

        const person = db.db('person');
        const student = person.collection('student');

        student.updateOne({

            "name": "insert in nodejs test03"

        }, { $set: { "name" : "test" } }, function(error, result) {
            var re = JSON.parse(result);
            if (re.n === 1) {
                res.send("修改成功袍镀。");
            } else {
                res.send("修改失敗,error:" + error);
            }
            res.end();
            db.close();
        })
    })
})
// 刪
app.get('/delete',function(req, res) {

    var query = url.parse(req.url,true).query;
    var name = query.name;

    MongoClient.connect(dbURL,function(err, db) {

        assert.equal(err,null);

        const person = db.db('person');
        const student = person.collection('student');  

        student.deleteOne({ "name": name }, function(error, result) {
            var re = JSON.parse(result);
            if (re.n === 1) {
                res.send("刪除成功。");
            } else {
                res.send("刪除失敗,error:" + error);
            }
            res.end();
            db.close();
        })
    })
})
4.封裝一下:

/modules/db.js

var MongoClient = require('mongodb').MongoClient;
var dbUrl ='mongodb://localhost:27017';


function connectDb(callback) {
    MongoClient.connect(dbUrl,function(err,db){
        if(err) {
            console.log('數(shù)據(jù)庫連接失敗');
            return;
        }
        callback(db);
        db.close();
    })
}

exports.findOne = function(dbname,collectionname,json,callback){

    connectDb(function(db) {
        const DB = db.db(dbname);
        const collection = DB.collection(collectionname);
        var result = collection.findOne(json,null,callback);
    });
}

exports.find = function(dbname,collectionname,json,callback) {
    connectDb(function(db) {
        const DB = db.db(dbname);
        const collection = DB.collection(collectionname);
        var result = collection.find(json).toArray(callback);
    });
}

exports.insertOne = function(dbname,collectionname,json,callback){
    connectDb(function(db) {
        const DB = db.db(dbname);
        const collection = DB.collection(collectionname);
        collection.insertOne(json,callback)
    })

}

然后在server.js中導(dǎo)入:

var DB = require('./modules/db.js');

使用:

app.post('/submit',function(req,res) {
    var username = req.body.username;
    var password = md5(req.body.password); 
        
    DB.findOne('person','userinfo',{"username":username, "password":password}, function(error, docs) {
        if(docs === null) {
            res.send("<script>alert('登錄失敗');location.href='/login'</script>");
        } else {
            req.session.userinfo = docs;
            res.redirect('/product');  /*登錄成功跳轉(zhuǎn)到商品列表*/
        }
    });
})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末母剥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子形导,更是在濱河造成了極大的恐慌环疼,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件朵耕,死亡現(xiàn)場離奇詭異炫隶,居然都是意外死亡,警方通過查閱死者的電腦和手機阎曹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進(jìn)店門伪阶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來煞檩,“玉大人,你說我怎么就攤上這事望门⌒谓浚” “怎么了?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵筹误,是天一觀的道長桐早。 經(jīng)常有香客問我,道長厨剪,這世上最難降的妖魔是什么哄酝? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮祷膳,結(jié)果婚禮上陶衅,老公的妹妹穿的比我還像新娘。我一直安慰自己直晨,他們只是感情好搀军,可當(dāng)我...
    茶點故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著勇皇,像睡著了一般罩句。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上敛摘,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天门烂,我揣著相機與錄音,去河邊找鬼兄淫。 笑死屯远,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的捕虽。 我是一名探鬼主播慨丐,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼泄私!你這毒婦竟也來了咖气?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤挖滤,失蹤者是張志新(化名)和其女友劉穎崩溪,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體斩松,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡伶唯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了惧盹。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片乳幸。...
    茶點故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡瞪讼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出粹断,到底是詐尸還是另有隱情符欠,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布瓶埋,位于F島的核電站希柿,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏养筒。R本人自食惡果不足惜曾撤,卻給世界環(huán)境...
    茶點故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望晕粪。 院中可真熱鬧挤悉,春花似錦、人聲如沸巫湘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽尚氛。三九已至诀诊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間怠褐,已是汗流浹背畏梆。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工您宪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留奈懒,地道東北人。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓宪巨,卻偏偏與公主長得像磷杏,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子捏卓,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,512評論 2 359

推薦閱讀更多精彩內(nèi)容