使用Node操作MongoDB

来源:https://www.cnblogs.com/Molyp/archive/2018/01/11/8260753.html
-Advertisement-
Play Games

1.使用 MongoDB模塊 進行操作 首先在工作目錄安裝 mongodb 模塊, 2.使用 Mongoose模塊 進行操作 2.1 創建文件db.js用來連接(其實這一步也有一點問題,不應該把資料庫連接寫到這裡) //創建文件 db.js // 在這之前你應該已經安裝了 mongoose || c ...


1.使用 MongoDB模塊 進行操作

 首先在工作目錄安裝 mongodb 模塊,

1 cnpm i mongodb//引入模塊
const MongoClient = require('mongodb').MongoClient;
//寫連接字元串,我的資料庫地址如下,所以當你在寫的時候修改地址之後的內容就好
const DB_CONN_STR= 'mongodb://127.0.0.1/demo';
//記得打開mongod服務 ,不然等著一堆err吧

//寫一個插入數據的函數
const insertData = function(db,callback){
    let collection = db.collection('集合名');
    
    let data = [{"name":"AAA","age":"19"},{"name":"BBB","age":"20"}]
     // 向集合中添加數據
    collection.insert(data,function(err,result){
        if(err){
            console.log('Error'+err);
            return;
        }
        callback(result);
    });   
}
//連接資料庫 連接串 回調函數 MongoClient.connect(DB_CONN_STR, function(err, db) { console.log("Done"); //調用剛纔寫好的函數 insertData(db, function(result) { //輸出返回結果 console.log(result); //關閉連接 db.close(); }); });
2.使用 Mongoose模塊 進行操作  2.1 創建文件db.js用來連接(其實這一步也有一點問題,不應該把資料庫連接寫到這裡)
//創建文件 db.js
// 在這之前你應該已經安裝了 mongoose || cnpm install mongoose
// 並且開啟了mongod服務 
import  mongoose from 'mongoose';
//mongoose.connect('mongodb://127.0.0.1:27017/demo'); 
//如果只是入地址,會報一個警告,不是錯誤,只屬於是不推薦的寫法.推薦下麵這麼寫
mongoose.connect('mongodb://地址/資料庫名',{useMongoClient: true});
const db = mongoose.connection;
// 
db.on('error',console.error.bind(console,'connection error:'));

db.once('open',function(callback){
     console.log("connection start");
});
db.on('disconnected',function(){
   console.log("connstion is disconnected");
});

module.exports = mongoose;

 2.2 Shema 

創建文件stu.js保存操作

Mongoose中的一切來自於Schema。每個Schema都會映射到MongoDB集合(collection)並定義該集合(collection)中的文檔的 形狀(類型)。
// 如名字所示,我們要創建的是 名字為 user 的Schmea
//如果以後要添加其他鍵,請使用Schema.add({})方法。
//引入剛纔寫好的模塊
import mongoose from './db'
const Shema = mongoose.Schema;
const UserShema = new Schema({
    name : {type:String},
    age : {type:Number},
    class : {type:String}
})

// Schema Types內置類型如下:
// String,Number,Boolean | Bool,Array,Buffer,Date,ObjectId | Oid,Mixed
// 如果你發現少了什麼屬性,可以使用 Shame.add();追加
UserShema.add{mail : 'String',pwd : 'String'}
// 然後使用 Schema 創建我們的model ,再加入到模塊,這一步驟很重要
module.exports = mongoose.model('Student',UserSchema)

   2.3 Shema 的使用(增加篇)

//
//
在 import user.js的時候 啟動了 mongoose.model('Classes',ClassSchema);參見上面的最後一段代碼 import student from './stu' class mannager{ //第一種創建方式 add(){ let newStu = new student({ name : '張三', age : 25, class : '大四' }); newStu.save(function (err) { if (err) return handleError(err); }); } //第二種創建方式 add2(){ student.create({ name : '張三', age : 25, class : '大四' },function(err){ if (err) return handleError(err); }); }     }

  Shema 的使用(查詢篇)

 mongoose
支持豐富的查詢MongoDB語法。文件可以使用每個模型中使用 find,findById,findOne,或者where,靜態方法。

 

 //查詢所有
    findAll(){
      return student.find(function(err,res){
            if (err) {
                return err;
            }else{
                let json = JSON.stringify(res); 
                return res;
            }
        });
    }
    //按照條件查詢
    findByAge(age){
        return student.find({Age : age},function(err,res){
            if (err) {
                return err;
            }else{
                let json = JSON.stringify(res); 
                return res;
            }
        });
    }
    //多種條件
    findTest(){
        return Tank.find(
            { class: '大三' }).where('Age').gt(20).exec(callback);
    }

 

 

API文檔包含了許多額外的方法,像 countmapReduceaggregate更多。在這裡就不一一舉慄子了

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 學完這本書,就把精華都寫出了 ...
  • NO是常開(NORMAL OPEN),就是通常即未通電狀態下,是斷開的,通電後在電磁線圈的作用下(吸合)處於閉合狀態。NC是常閉(NORMAL CLOSE),就是通常即未通電狀態下,是閉合的,通電後在電磁線圈的作用下(吸合)處於斷開狀態。 指接觸器、繼電器等電氣開關元件輔助觸點在常態下(未通電時)的 ...
  • 背景 iPhone X 劉海機於9月13日發佈,給科技小春晚帶來一波高潮。作為開發人員卻多出來一份憂慮,iPhone X 怎麼適配?我們 App 的腦袋會不會也長一劉海出來?Tabbar 會不會被圓角?先來看一下美團 App 的表現: 圖 1.1 啟動時的 App 表現 圖 1.2 下拉刷新之後的表 ...
  • iOS11對WKWebView的功能進一步完善,新增如下功能: ...
  • 今天研究了一下在Xcode中創建多個工程,達到模塊化的目的的同時,實現多個相似項目的協同開發,最主要的是可以實現多工程連編。項目的效果如下: 接下來創建一個這樣的項目,以及他們之間的通信 1.建一個文件夾MyProject(這是本人採用的文件夾) 2.在MyProject文件夾下創建一個工作空間My ...
  • 一. 背景 PS:相關知識:ListView與RecyclerView緩存機制原理大致相似,如下圖所示: 滑動過程中,離屏的ItemView即被回收至緩存,入屏的ItemView則會優先從緩存中獲取,只是ListView與RecyclerView的實現細節有差異.(這隻是緩存使用的其中一個場景,還有 ...
  • 之前一直做的是.NET開發用的是C#語言,近段時間由於做一個APP這才用上了java,在二維碼掃描整合到APP裡面遇到掃描二維碼之後沒有返回值,經過反覆的嘗試最後終於拿到了返回值,之後覺得很有必要記錄一下所以在這裡分享出來。 在網上下載Zxing開源包之後導入AndroidStudio 在Mainf ...
  • CSS3的過渡和轉換 1.過渡 什麼是過渡呢?過渡通俗的來說就是從一個樣式到另一個樣式的逐漸轉換改變的效果。 過渡的屬性: transition:是一個簡寫屬性,用於設置四個過渡屬性,所以說我們用的時候只寫這個屬性就行了。 transition-property:規定應用過渡效果的屬性(可以設置單個 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...