欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDB的基本操作實(shí)例詳解【服務(wù)端啟動(dòng),客戶端連接,CRUD操作】

 更新時(shí)間:2020年04月10日 11:30:37   作者:隨風(fēng)行云  
這篇文章主要介紹了MongoDB的基本操作,結(jié)合實(shí)例形式分析了MongoDB數(shù)據(jù)庫(kù)的服務(wù)端啟動(dòng),客戶端連接,CRUD操作等基本實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了MongoDB的基本操作。分享給大家供大家參考,具體如下:

本文內(nèi)容:

  • MongoDB的介紹
  • MongoDB服務(wù)端的啟動(dòng)
  • MongoDB客戶端連接
  • SQL與MongoDB相關(guān)概念解釋
  • 什么是BSON
  • 數(shù)據(jù)庫(kù)操作
  • 集合操作
  • 文檔操作

測(cè)試環(huán)境:win10

軟件版本:3.6.2

首發(fā)時(shí)間:2018-03-18 15:38


MongoDB的介紹:

  • MongoDB 是由C++語(yǔ)言編寫(xiě)的開(kāi)源數(shù)據(jù)庫(kù)系統(tǒng)。
  • MongoDB 將數(shù)據(jù)存儲(chǔ)為一個(gè)文檔。MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)。
  • MongoDB的提供了一個(gè)面向文檔存儲(chǔ),操作起來(lái)比較簡(jiǎn)單和容易
  • 可以在MongoDB記錄中設(shè)置任何屬性的索引
  • Mongo支持豐富的查詢表達(dá)式。查詢指令使用JSON形式的標(biāo)記,可輕易查詢文檔中內(nèi)嵌的對(duì)象及
    數(shù)組。
  • MongoDB支持多個(gè)存儲(chǔ)引擎:wireTiger、 MMaPv1等等

MongoDB服務(wù)端的啟動(dòng):

使用mongod命令來(lái)啟動(dòng)服務(wù)端

  • mongodb常用啟動(dòng)參數(shù)

    • --bind_ip:綁定服務(wù)IP,若綁定127.0.0.1,則只能本機(jī)訪問(wèn),不指定默認(rèn)本地所有IP

    • --port:指定服務(wù)端口號(hào),默認(rèn)端口27017

    • --logpath:指定MongoDB日志文件存放路徑

    • --dbpath:指定數(shù)據(jù)庫(kù)路徑【需要指定才能啟動(dòng)成功】

    • --serviceName:指定服務(wù)名稱 【主要用于安裝服務(wù)時(shí)指定名稱】

    • --serviceDisplayName:指定服務(wù)名稱,有多個(gè)mongodb服務(wù)時(shí)執(zhí)行?!局饕糜诎惭b服務(wù)時(shí)指定名稱】

想獲得更多參數(shù)信息,可以輸入:

mongod --help
或
mongod -h

將MongoDB服務(wù)器作為Windows服務(wù)運(yùn)行:

上面的啟動(dòng)方式需要掛起一個(gè)窗口。

如果不想一直掛起一個(gè)窗口,也可以將這些啟動(dòng)參數(shù)添加到服務(wù)中,將mongod作為一個(gè)服務(wù)啟動(dòng),這樣就不需要那么麻煩了。

image

輸入命令例子如下:

mongod --dbpath "D:\data\db" --logpath "D:\data\log\mongodb.log" --serviceName "mongodb" --serviceDisplayName "mongodb" --install
  • 安裝服務(wù)必須參數(shù)介紹:
    • --install:指示安裝成服務(wù)
    • --serviceName:指定服務(wù)名稱
    • --serviceDisplayName:指定服務(wù)名稱,有多個(gè)mongodb服務(wù)時(shí)執(zhí)行
    • 其他設(shè)置都是可選的,按自己需求來(lái)確認(rèn)是否填寫(xiě)。

這樣就只需要在使用的時(shí)候啟動(dòng)mongod服務(wù)即可。


MongoDB客戶端連接:

使用mongo命令來(lái)連接服務(wù)端。

mongo [options] [db address] [file names (ending in .js)]
本地服務(wù)端可以使用:mongo 或者mongo localhost
遠(yuǎn)程的可以使用:mongo IP地址

image

想獲取更多參數(shù)設(shè)置信息,可以輸入一下命令:

mongo --help
或
mongo -h

SQL與MongoDB相關(guān)概念解釋:

這個(gè)相關(guān)概念解釋是為了讓一些有了SQL學(xué)習(xí)經(jīng)驗(yàn)(沒(méi)有的應(yīng)該也能了解)的人更快了解MongoDB的結(jié)構(gòu)

image


什么是BSON:

  • BSON()是一種類(lèi)json的一種二進(jìn)制形式的存儲(chǔ)格式,簡(jiǎn)稱Binary JSON,它和JSON一樣,支持內(nèi)嵌的文檔對(duì)象和數(shù)組對(duì)象,但是BSON有JSON沒(méi)有的一些數(shù)據(jù)類(lèi)型,如Date和BinData類(lèi)型。
  • BSON可以做為網(wǎng)絡(luò)數(shù)據(jù)交換的一種存儲(chǔ)形式,這個(gè)有點(diǎn)類(lèi)似于Google的Protocol Buffer,但是BSON是一種schema-less的存儲(chǔ)形式,它的優(yōu)點(diǎn)是靈活性高,但它的缺點(diǎn)是空間利用率不是很理想,
  • BSON有三個(gè)特點(diǎn):輕量性、可遍歷性、高效性
  • BSON的例子:{"name":"alex","age":18}
  • BSON支持的數(shù)據(jù)類(lèi)型:
    • image

數(shù)據(jù)庫(kù)操作:

  • 顯示所有數(shù)據(jù)庫(kù)【注意,數(shù)據(jù)為空的數(shù)據(jù)庫(kù)默認(rèn)不顯示出來(lái)】:
    show dbs
  • 顯示當(dāng)前數(shù)據(jù)庫(kù)對(duì)象或者集合:
    db
  • 切換數(shù)據(jù)庫(kù),如果數(shù)據(jù)庫(kù)不存在就創(chuàng)建數(shù)據(jù)庫(kù)再切換到指定數(shù)據(jù)庫(kù):
    use 數(shù)據(jù)庫(kù)名
  • 創(chuàng)建數(shù)據(jù)庫(kù): use 數(shù)據(jù)庫(kù)名
    • 數(shù)據(jù)庫(kù)名稱可以是任何字符,但是不能包含空字符串,點(diǎn)號(hào)(.),或者" "。
    • 默認(rèn)的數(shù)據(jù)庫(kù)為test,如果你沒(méi)有創(chuàng)建新的數(shù)據(jù)庫(kù),集合將存放在test數(shù)據(jù)庫(kù)中
  • 刪除數(shù)據(jù)庫(kù):
    • db.dropDatabase():刪除當(dāng)前數(shù)據(jù)庫(kù),建議先用db命令確認(rèn)一下當(dāng)前數(shù)據(jù)庫(kù)

集合操作:

  • 在mongodb中的集合是無(wú)模式的,mongodb中并沒(méi)有嚴(yán)格的約束插入的數(shù)據(jù),集合中存儲(chǔ)的文檔的結(jié)構(gòu)可以是不同的。
    • 下面的兩個(gè)文檔可以同時(shí)存入到一個(gè)集合中:{"name":"alex"} {"age":18,"sex":"man"}
    • image
  • 集合的命名:
    • 集合名稱必須以字母或下劃線開(kāi)頭。
    • 集合名可以保護(hù)數(shù)字
    • 集合名稱不能使美元符"$","$"是系統(tǒng)保留字符。
    • 集合的名字 最大不能超過(guò)128個(gè)字符 。
    • 另外,"."號(hào)的使用在集合當(dāng)中是允許的,它們被成為子集合(Subcollection);
    • 創(chuàng)建集合:
db.createCollection(name, {size: ..., capped: ..., max: ...})
    • name是集合名
    • size,capped,max是可選項(xiàng):size代表集合大小,capped代表是否限制集合大小(size來(lái)設(shè)置),max代表集合的最大文檔數(shù)量
    • 可選項(xiàng)還有很多,想了解更多可以參考官方文檔,比如還有storageEngine,collation。。。
  • 查看當(dāng)前數(shù)據(jù)庫(kù)所有集合:
    show collections
  • 刪除集合:
    db.集合名.drop()
  • 修改集合名:
    db.集合名.renameCollection()
  • 獲取集合幫助信息:
    db.集合名.help()

文檔操作:

  • 插入文檔:
    • db.集合名.insert(document):document是一個(gè)BSON格式的。
      db.users.insertOne({ name: "sue",age: 19,status: "P"})
    • db.集合名.insertOne(document):document是一個(gè)BSON格式的。
      db.teacher.insert({name: "sue"})
      db.teacher.insert([{"name":"Lili"},{"name":"Alex"}])
    • db.集合名.insertMany([document,document,document……]):document是一個(gè)BSON格式的。
      db.users.insertMany( [{ name: "bob", age: 42, status: "A", },{ name: "ahn", age: 22, status: "A", },{ name: "xi", age: 34, status: "D", }])
    • image
    • image
  • 查看數(shù)據(jù):
    • db.集合名.find(<query filter>, <projection>)
    • db.集合名.findone(<query filter>, <projection>):只返回一個(gè)文檔
    • query filter可以有如下:
      • {}:代表返回所有文檔,db.集合名.find({}),等價(jià)于db.集合名.find()
        db.teacher.find()
      • {key1:value1,key2:value2…}:返回key1==value1 and key2==value2的文檔;
        db.teacher.find({name:"alex"})
        db.teacher.find({name:"jack",course:"linux"})
      • { <key1>: { <operator1>: <value1> }, ... }:
        • operator可以有 $lt小于, $gt大于,$gte大于等于, $lte小于等于, $ne不等于
          db.class.find({"member":{$gt:5}})
          db.class.find({"member":{$gt:5},grade:{$gt:3}})
    • query filter多個(gè)條件的andor
      • 默認(rèn)情況多個(gè)條件下是and的,多個(gè)條件用逗號(hào)分開(kāi)
      • 如果想要使用or:{$or[{<key>:<value>},{<key>:<value>},{<key>:<value>}……]}
        • image
      • andor的聯(lián)合使用: ({and條件,$or:[or條件]})
      • db.teacher.find({course:"linux",$or:[{name:"Lili"},{name:"Alex"}]})
        • image
    • query filter的條件還可以是類(lèi)型檢測(cè):使用$type來(lái)進(jìn)行類(lèi)型檢測(cè),type檢測(cè)的類(lèi)型數(shù)字,根據(jù)上面BSON類(lèi)型表中的數(shù)值。
      • 篩選出字段數(shù)據(jù)類(lèi)型是否是double型的: $type:1
      • 篩選出字段數(shù)據(jù)類(lèi)型是否是string型的: $type:2
      • 篩選出字段數(shù)據(jù)類(lèi)型是否是boolean型的: $type:8
      • 篩選出字段數(shù)據(jù)類(lèi)型是否是Null型的: $type:10
      • …..其他
      • image
      • image
    • 如果想要以格式化的方式來(lái)查看文檔db.集合名.find().pretty()
      • 普通格式:image
      • pretty格式:image
  • 更新文檔:
    • 更新文檔可以使用下面幾個(gè):
      • db.集合名.updateOne(<query>,<update>,{option}):更新單條文檔
      • db.集合名.updateMany(<query>,<update>,{option}):更新多條文檔
      • db.集合名.update(<query>,<update>,{option}):更新文檔,可選單條文檔或多條文檔
    • query是BSON格式的,作為查找文檔的條件 ,query的條件參考上面查找文檔中的query filter
    • update是BSON格式的,指明了如何修改文檔 ,修改哪些字段
      •   注意,修改字段值需要加上{$set:{"key":"newvalue"}},不然{key:"newvalue"}會(huì)替換原來(lái)的文檔,導(dǎo)致其他字段數(shù)據(jù)丟失
    • option:
      • upsert是如果對(duì)應(yīng)不存在要修改的數(shù)據(jù),是否將新的數(shù)據(jù)插入。默認(rèn)是false不插入
      • db.集合名.update()中的multi是默認(rèn)是false,只更新查找到的第一條文檔數(shù)據(jù),如果改成true,將更新所有可匹配的文檔。
      • writeConcern是拋出異常的級(jí)別。

  • 刪除數(shù)據(jù):
    • db.集合名.remove(query):刪除所有符合條件的文檔
      • query :刪除的文檔的條件。如果條件為{},則刪除所有文檔image ,query可以參考查找文檔中的query filter
      • justOne : (可選)如果設(shè)為 true 或 1,則只刪除一個(gè)文檔。
      • writeConcern :(可選)拋出異常的級(jí)別。

想了解更多可以參考官方文檔。https://docs.mongodb.com/manual/reference/bson-types/

image

希望本文所述對(duì)大家MongoDB數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 詳解清除MongoDB所占用的多余的磁盤(pán)空間的方法

    詳解清除MongoDB所占用的多余的磁盤(pán)空間的方法

    MongoDB不會(huì)自動(dòng)進(jìn)行垃圾文件清理,不過(guò)我們可以借助自帶的repairDatabase等功能來(lái)實(shí)現(xiàn),下面我們就來(lái)詳解清除MongoDB所占用的多余的磁盤(pán)空間的方法,附帶一個(gè)如何格式化mongo shell的輸出的小技巧:
    2016-06-06
  • 2021最新版windows10系統(tǒng)MongoDB數(shù)據(jù)庫(kù)安裝及配置環(huán)境

    2021最新版windows10系統(tǒng)MongoDB數(shù)據(jù)庫(kù)安裝及配置環(huán)境

    這篇文章主要介紹了2021最新版MongoDB數(shù)據(jù)庫(kù)安裝及配置環(huán)境(windows10系統(tǒng)),本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • MongoDB中創(chuàng)建索引需要注意的事項(xiàng)

    MongoDB中創(chuàng)建索引需要注意的事項(xiàng)

    這篇文章主要介紹了MongoDB中創(chuàng)建索引需要注意的事項(xiàng),本文講解了創(chuàng)建索引可能會(huì)引發(fā)的問(wèn)題并給出解決方法,需要的朋友可以參考下
    2015-03-03
  • mongodb replica set 添加刪除節(jié)點(diǎn)的2種方法

    mongodb replica set 添加刪除節(jié)點(diǎn)的2種方法

    replica set多服務(wù)器主從,添加,刪除節(jié)點(diǎn),肯定會(huì)經(jīng)常遇到的。下面詳細(xì)說(shuō)明一下,添加,刪除節(jié)點(diǎn)的2種方法。
    2014-07-07
  • MongoDB聚合運(yùn)算符$dateFromString詳解

    MongoDB聚合運(yùn)算符$dateFromString詳解

    $dateFromString聚合運(yùn)算符將日期時(shí)間字符串轉(zhuǎn)換為日期對(duì)象,本文給大家介紹MongoDB聚合運(yùn)算符$dateFromString的相關(guān)知識(shí),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • mongodb 隨機(jī)獲取一條記錄的方法

    mongodb 隨機(jī)獲取一條記錄的方法

    這篇文章主要介紹了 mongodb 隨機(jī)獲取一條記錄的方法的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • 淺析MongoDB之安全認(rèn)證

    淺析MongoDB之安全認(rèn)證

    MongoDB是基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)。由C++語(yǔ)言編寫(xiě)。旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案。默認(rèn)情況下,MongoDB實(shí)例啟動(dòng)運(yùn)行時(shí)是沒(méi)有啟用用戶訪問(wèn)權(quán)限控制的,在實(shí)例本機(jī)服務(wù)器上都可以隨意連接到實(shí)例進(jìn)行各種操作,MongoDB不會(huì)對(duì)連接客戶端進(jìn)行用戶驗(yàn)證
    2021-06-06
  • 在MongoDB中實(shí)現(xiàn)時(shí)間范圍查詢的代碼詳解

    在MongoDB中實(shí)現(xiàn)時(shí)間范圍查詢的代碼詳解

    MongoDB作為一個(gè)高性能、開(kāi)源、無(wú)模式的文檔型數(shù)據(jù)庫(kù),廣泛應(yīng)用于各種需要靈活數(shù)據(jù)模型的應(yīng)用場(chǎng)景中,在處理與時(shí)間相關(guān)的數(shù)據(jù)時(shí),MongoDB提供了強(qiáng)大的查詢能力,本文將詳細(xì)介紹如何在MongoDB中執(zhí)行時(shí)間范圍查詢,需要的朋友可以參考下
    2024-08-08
  • MongoDB實(shí)現(xiàn)自動(dòng)備份的全過(guò)程記錄

    MongoDB實(shí)現(xiàn)自動(dòng)備份的全過(guò)程記錄

    這篇文章主要給大家介紹了關(guān)于MongoDB實(shí)現(xiàn)自動(dòng)備份的全過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • MongoDB加入到Windows服務(wù)的方法

    MongoDB加入到Windows服務(wù)的方法

    這篇文章主要介紹了Windows中把MongoDB加入到本地服務(wù)的方法,即把MongoDB加入到Windows服務(wù)中隨機(jī)啟動(dòng),需要的朋友可以參考下
    2014-10-10

最新評(píng)論