国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

使用Nodejs連接mongodb數據庫的實現代碼

2024-05-06 16:39:10
字體:
來源:轉載
供稿:網友

一個簡單的nodejs連接mongodb示例,來自 mongodb官方示例

1. 創建package.json

首先,創建我們的工程目錄connect-mongodb,并作為我們的當前目錄

mkdir connect-mongodbcd connect-mongodb

輸入npm init命令創建package.json

npm init

然后,安裝mongodb的nodejs版本driver

npm install mongodb --save

mongodb驅動包將會安裝到當前目錄下的node_modules中

2. 啟動MongoDB服務器

安裝MongoDB并啟動MongoDB數據庫服務,可參考我之前的文章,或者MongoDB官方文檔

3. 連接MongoDB

創建一個app.js文件,并添加以下代碼來連接服務器地址為192.168.0.243,mongodb端口為27017上名稱為myNewDatabase的數據庫

var MongoClient = require('mongodb').MongoClient,  assert = require('assert');// Connection URLvar url = 'mongodb://192.168.0.243:27017/myNewDatabase';MongoClient.connect(url,function(err,db){  assert.equal(null,err);  console.log("Connection successfully to server");  db.close();});

在命令行輸入以下命令運行app.js

node app.js

4. 插入文檔

在app.js中添加以下代碼,使用insertMany方法添加3個文檔到documents集合中

var insertDocuments = function(db, callback){  // get ths documents collection  var collection = db.collection('documents');  // insert some documents  collection.insertMany([    {a:1},{a:2},{a:3}  ],function(err,result){    assert.equal(err,null);    assert.equal(3,result.result.n);    assert.equal(3,result.ops.length);    console.log("Inserted 3 documents into the collection");    callback(result);  });};

insert命令返回一個包含以下屬性的對象:

  • result MongoDB返回的文檔結果
  • ops 添加了_id字段的文檔
  • connection 執行插入操作所使用的connection

在app.js更新以下代碼調用insertDocuments方法

var MongoClient = require('mongodb').MongoClient , assert = require('assert');// Connection URLvar url = 'mongodb://localhost:27017/myproject';// Use connect method to connect to the serverMongoClient.connect(url, function(err, db) { assert.equal(null, err); console.log("Connected successfully to server"); insertDocuments(db, function() {  db.close(); });});

在命令行中使用node app.js運行

5. 查詢所有文檔

添加findDocuments函數

var findDocuments = function(db,callback){  // get the documents collection  var collection = db.collection('documents');  // find some documents  collection.find({}).toArray(function(err,docs){    assert.equal(err,null);    console.log("Found the following records");    console.log(docs);    callback(docs);  });};

findDocuments函數查詢了所有'documents'集合中所有的文檔,將此函數添加到MongoClient.connect的回調函數中

var MongoClient = require('mongodb').MongoClient , assert = require('assert');// Connection URLvar url = 'mongodb://localhost:27017/myproject';// Use connect method to connect to the serverMongoClient.connect(url, function(err, db) { assert.equal(null, err); console.log("Connected correctly to server"); insertDocuments(db, function() {  findDocuments(db, function() {   db.close();  }); });});

6. 使用過濾條件(query filter)查詢文檔

查詢'a':3的文檔

var findDocuments = function(db, callback) { // Get the documents collection var collection = db.collection('documents'); // Find some documents collection.find({'a': 3}).toArray(function(err, docs) {  assert.equal(err, null);  console.log("Found the following records");  console.log(docs);  callback(docs); });   }

7. 更新文檔

var updateDocument = function(db,callback){  // get the documents collection  var collection = db.collection('documents');  // update document where a is 2, set b equal to 1  collection.updateOne({a:2},{    $set:{b:1}  },function(err,result){    assert.equal(err,null);    assert.equal(1,result.result.n);    console.log("updated the document with the field a equal to 2");    callback(result);  });};

updateDocument方法更新滿足條件a為2的第一個文檔,新增一個b屬性,并將其設置為1。

將updateDocument方法添加到MongoClient.connect方法的回調中

MongoClient.connect(url,function(err,db){  assert.equal(null,err);  console.log("Connection successfully to server");  insertDocuments(db,function(){    updateDocument(db,function(){      db.close();    });  });});

8. 刪除文檔

var removeDocument = function(db,callback){  // get the documents collection  var collection = db.collection('documents');  // remove some documents  collection.deleteOne({a:3},function(err,result){    assert.equal(err,null);    assert.equal(1,result.result.n);    console.log("removed the document with the field a equal to 3");    callback(result);  });};

添加到app.js中

var MongoClient = require('mongodb').MongoClient , assert = require('assert');// Connection URLvar url = 'mongodb://localhost:27017/myproject';// Use connect method to connect to the serverMongoClient.connect(url, function(err, db) { assert.equal(null, err); console.log("Connected successfully to server"); insertDocuments(db, function() {  updateDocument(db, function() {   removeDocument(db, function() {    db.close();   });  }); });});

9. 創建索引

索引能夠改善應用的性能。下面你代碼在'a'屬性上添加索引

var indexCollection = function(db,callback){  db.collection('documents').createIndex({    a:1  },null,function(err,results){    console.log(results);    callback();  });};

更新app.js

MongoClient.connect(url,function(err,db){  assert.equal(null,err);  console.log("Connection successfully to server");  insertDocuments(db,function(){    indexCollection(db,function(){      db.close();    });  });});

代碼已經托管在碼云

總結

以上所述是小編給大家介紹的使用Nodejs連接mongodb數據庫的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 松溪县| 永安市| 海安县| 锦州市| 习水县| 莎车县| 开化县| 内乡县| 寿宁县| 乃东县| 绵竹市| 河源市| 桂平市| 大同县| 西和县| 花莲市| 河间市| 观塘区| 枝江市| 呼伦贝尔市| 海兴县| 天长市| 仙桃市| 上饶市| 弋阳县| 即墨市| 金溪县| 朔州市| 米脂县| 田林县| 乌什县| 安吉县| 衡阳市| 中超| 桦甸市| 永州市| 吉林省| 黔东| 白朗县| 砀山县| 盐亭县|