摘要:系列文章的安裝的命令操作的編程操作前面文章首先介紹了數(shù)據(jù)庫(kù)系統(tǒng)的安裝,接著介紹了的工具來(lái)操作數(shù)據(jù)庫(kù),掌握了命令行對(duì)數(shù)據(jù)庫(kù)的增刪改查,四個(gè)基本操作。現(xiàn)在來(lái)介紹,如何用編程語(yǔ)言來(lái)操作數(shù)據(jù)庫(kù)。
MongoDB 系列文章:
MongoDB 的 yum 安裝
MongoDB 的命令操作
MongoDB 的編程操作
前面文章首先介紹了 MongoDB 數(shù)據(jù)庫(kù)系統(tǒng)的安裝,接著介紹了 MongoDB 的 Shell 工具來(lái)操作數(shù)據(jù)庫(kù),掌握了命令行對(duì)數(shù)據(jù)庫(kù)的增、刪、改、查,四個(gè)基本操作。現(xiàn)在來(lái)介紹,如何用 JavaScript 編程語(yǔ)言來(lái)操作 MongoDB 數(shù)據(jù)庫(kù)。
假設(shè)有一個(gè)編程任務(wù),希望在 node.js 程序中將數(shù)據(jù)持久保存到 MongoDB 數(shù)據(jù)庫(kù)中,請(qǐng)問(wèn)這樣的編程任務(wù)該如何實(shí)現(xiàn)呢?
下面咱們通過(guò)具體案例,展示用 JavaScript 程序?qū)崿F(xiàn)對(duì) MongoDB 數(shù)據(jù)庫(kù)的增、刪、改、查四個(gè)基本操作。當(dāng)然,在操作之前,首先需要安裝數(shù)據(jù)庫(kù)操作的 Node.js 第三方模塊:mongodb。
npm install mongodb
然后,編寫下面的 opt-mongo.js 代碼文件。
#!/usr/bin/node var MongoClient = require("mongodb").MongoClient, assert = require("assert"); var url = "mongodb://localhost:27017/todo"; MongoClient.connect(url, function(err, db) { assert.equal(null, err); //db.collection("todo").insertOne({"item": "have break"}); db.collection("todo").updateOne({"item": "have breakfast"}, {"itrem": "have launch"}); //db.collection("todo").deleteOne({"item": "have break"}); find(db, function() {db.close();}); }); function find(db, cb) { var cursor = db.collection("todo").find(); cursor.each(function(err, doc) { if(doc !== null) { console.log(doc); } else { cb(); } }); }
程序說(shuō)明:
首先引用 MongoDB 的客戶端,通過(guò)客戶端可以和 MongoDB 服務(wù)器建立連接;
引用 assert 斷言模塊,判斷連接是否出錯(cuò);
定義變量 url 保存 MongoDB 服務(wù)器的地址,假設(shè)咱們操作的是 todo 待辦事項(xiàng)列表的數(shù)據(jù)庫(kù);
調(diào)用客戶端的 connect 方法,連接 MongoDB 數(shù)據(jù)庫(kù);
回調(diào)函數(shù)兩個(gè)參數(shù),第一個(gè)參數(shù)是 Error 對(duì)象,第二個(gè)參數(shù)是數(shù)據(jù)庫(kù)對(duì)象;
增、刪、改、查四個(gè)操作都在數(shù)據(jù)庫(kù)對(duì)象上做操作;
先定義一個(gè)查詢函數(shù) find,兩個(gè)參數(shù),第一個(gè)參數(shù)是數(shù)據(jù)庫(kù)對(duì)象,第二個(gè)參數(shù)是回調(diào)函數(shù);
find 函數(shù)中,你會(huì)發(fā)現(xiàn) JavaScript 編程的 API 和 MongoDB Shell 的 API 幾乎相同;
find 函數(shù)定義好了,在連接方法的回調(diào)里面調(diào)用 find 方法;
執(zhí)行程序,看一下數(shù)據(jù)庫(kù)查詢的效果;
然后,再查詢語(yǔ)句前面分別添加:增、刪和改,三條語(yǔ)句;
每添加一個(gè)語(yǔ)句,在命令行運(yùn)行,查看效果;
注釋掉語(yǔ)句,然后再增加下一條語(yǔ)句;
通過(guò)上面的案例代碼,看到了對(duì) MongoDB 數(shù)據(jù)庫(kù)編程操作的簡(jiǎn)單和易用。這個(gè)文章只介紹了,增、刪、改、查四個(gè)基本操作的 API,作為拋磚引玉。如果希望更進(jìn)一步的學(xué)習(xí),請(qǐng)參考 MongoDB API 的官方文檔。Node.js 原生 API 沒(méi)有關(guān)于數(shù)據(jù)庫(kù)操作的模塊,對(duì)于數(shù)據(jù)庫(kù)操作都是使用第三方模塊來(lái)完成。另外一個(gè)常用的第三方模塊是 Mongoose 大家可以自行查閱相關(guān)資料。
如果這個(gè)文章對(duì)你有用,請(qǐng)點(diǎn)贊并收藏!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/19178.html
摘要:今天小編就來(lái)分享一份華為剛剛首發(fā)的響應(yīng)式微服務(wù)實(shí)戰(zhàn)這份主要包含響應(yīng)式微服務(wù)架構(gòu)實(shí)現(xiàn)過(guò)程中所應(yīng)具備的技術(shù)體系和工程實(shí)踐,在組織結(jié)構(gòu)上分如下篇。 今天小編就來(lái)分享一份華為剛剛首發(fā)的Spring響應(yīng)式微服務(wù)(Spring Boot 2+Spring 5+Spring Cloud實(shí)戰(zhàn))! 這份PDF...
摘要:文檔是的核心概念,文檔是操作數(shù)據(jù)庫(kù)的最小單元。等你了解這這些命令或者函數(shù),你再嘗試在腳本代碼中操作數(shù)據(jù)庫(kù),你會(huì)發(fā)現(xiàn)這種非常容易上手。 MongoDB 系列文章: MongoDB 的 yum 安裝 MongoDB 的命令操作 MongoDB 的編程操作 在介紹 MongoDB 的具體操作和使用之前,有必要介紹一些 MongoDB 的基本概念,有了這些基礎(chǔ)和知識(shí)鋪墊,后面的操作,才會(huì)掌...
摘要:學(xué)習(xí)已經(jīng)有三周了,是時(shí)候來(lái)一發(fā)學(xué)習(xí)總結(jié)啦。相關(guān)簡(jiǎn)介是非關(guān)系型的數(shù)據(jù)庫(kù)。簡(jiǎn)單在于,所有的都由大括號(hào),中括號(hào),以及對(duì)構(gòu)成。不同于,它是同步的。 學(xué)習(xí)mongoDB已經(jīng)有三周了,是時(shí)候來(lái)一發(fā)學(xué)習(xí)總結(jié)啦。以下是個(gè)人學(xué)習(xí)心得總結(jié),非官方,可能有紕漏和不準(zhǔn)確之處,歡迎指正。 相關(guān)簡(jiǎn)介 1.mongoDB是非關(guān)系型(nosql)的數(shù)據(jù)庫(kù)。 2.mongoDB是無(wú)模式(schemaless)的數(shù)...
摘要:可水平擴(kuò)展,可以添加更多服務(wù)器來(lái)擴(kuò)展您的數(shù)據(jù)庫(kù)需要管理員是否開發(fā)人員和管理員都可以使用適用場(chǎng)景會(huì)計(jì)師事務(wù)所和銀行,以及需要具有清晰架構(gòu)的結(jié)構(gòu)化數(shù)據(jù)的其他公司。 今天的主題是從MongoDB漫談數(shù)據(jù)庫(kù),在日常的項(xiàng)目中,我們一般都是使用的mysql作為數(shù)據(jù)庫(kù),但是一旦有問(wèn)題,又常常會(huì)聽到類似要不換成MongoDB試試的聲音,因此就讓我們這些小白來(lái)隨便聊聊數(shù)據(jù)庫(kù) 什么是數(shù)據(jù)庫(kù) 我們就用最簡(jiǎn)單...
閱讀 917·2021-10-18 13:32
閱讀 3513·2021-09-30 09:47
閱讀 2155·2021-09-23 11:21
閱讀 1878·2021-09-09 09:34
閱讀 3479·2019-08-30 15:43
閱讀 1522·2019-08-30 11:07
閱讀 1061·2019-08-29 16:14
閱讀 724·2019-08-29 11:06