MongoDB的基本操作實(shí)例詳解【服務(wù)端啟動(dòng),客戶(hù)端連接,CRUD操作】
本文實(shí)例講述了MongoDB的基本操作。分享給大家供大家參考,具體如下:
本文內(nèi)容:
- MongoDB的介紹
- MongoDB服務(wù)端的啟動(dòng)
- MongoDB客戶(hù)端連接
- 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支持豐富的查詢(xún)表達(dá)式。查詢(xún)指令使用JSON形式的標(biāo)記,可輕易查詢(xún)文檔中內(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ù)名稱(chēng) 【主要用于安裝服務(wù)時(shí)指定名稱(chēng)】
-
--serviceDisplayName:指定服務(wù)名稱(chēng),有多個(gè)mongodb服務(wù)時(shí)執(zhí)行?!局饕糜诎惭b服務(wù)時(shí)指定名稱(chēng)】
-
想獲得更多參數(shù)信息,可以輸入:
mongod --help 或 mongod -h
將MongoDB服務(wù)器作為Windows服務(wù)運(yùn)行:
上面的啟動(dòng)方式需要掛起一個(gè)窗口。
如果不想一直掛起一個(gè)窗口,也可以將這些啟動(dòng)參數(shù)添加到服務(wù)中,將mongod作為一個(gè)服務(wù)啟動(dòng),這樣就不需要那么麻煩了。

輸入命令例子如下:
mongod --dbpath "D:\data\db" --logpath "D:\data\log\mongodb.log" --serviceName "mongodb" --serviceDisplayName "mongodb" --install
- 安裝服務(wù)必須參數(shù)介紹:
- --install:指示安裝成服務(wù)
- --serviceName:指定服務(wù)名稱(chēng)
- --serviceDisplayName:指定服務(wù)名稱(chēng),有多個(gè)mongodb服務(wù)時(shí)執(zhí)行
- 其他設(shè)置都是可選的,按自己需求來(lái)確認(rèn)是否填寫(xiě)。
這樣就只需要在使用的時(shí)候啟動(dòng)mongod服務(wù)即可。
MongoDB客戶(hù)端連接:
使用mongo命令來(lái)連接服務(wù)端。
mongo [options] [db address] [file names (ending in .js)]
本地服務(wù)端可以使用:mongo 或者mongo localhost
遠(yuǎn)程的可以使用:mongo IP地址

想獲取更多參數(shù)設(shè)置信息,可以輸入一下命令:
mongo --help 或 mongo -h
SQL與MongoDB相關(guān)概念解釋?zhuān)?/h1>
這個(gè)相關(guān)概念解釋是為了讓一些有了SQL學(xué)習(xí)經(jīng)驗(yàn)(沒(méi)有的應(yīng)該也能了解)的人更快了解MongoDB的結(jié)構(gòu)

什么是BSON:
- BSON()是一種類(lèi)json的一種二進(jìn)制形式的存儲(chǔ)格式,簡(jiǎn)稱(chēng)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)型:
-
數(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ù)名稱(chēng)可以是任何字符,但是不能包含空字符串,點(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"}

- 集合的命名:
- 集合名稱(chēng)必須以字母或下劃線開(kāi)頭。
- 集合名可以保護(hù)數(shù)字
- 集合名稱(chēng)不能使美元符"$","$"是系統(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", }]) 

- db.集合名.insert(document):document是一個(gè)BSON格式的。
查看數(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}})
- operator可以有 $lt小于, $gt大于,$gte大于等于, $lte小于等于, $ne不等于
- {}:代表返回所有文檔,db.集合名.find({}),等價(jià)于db.集合名.find()
query filter多個(gè)條件的and和or:- 默認(rèn)情況多個(gè)條件下是
and的,多個(gè)條件用逗號(hào)分開(kāi) - 如果想要使用or:{$or[{<key>:<value>},{<key>:<value>},{<key>:<value>}……]}
-
and和or的聯(lián)合使用:({and條件,$or:[or條件]})-
db.teacher.find({course:"linux",$or:[{name:"Lili"},{name:"Alex"}]})
- 默認(rèn)情況多個(gè)條件下是
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 - …..其他


- 篩選出字段數(shù)據(jù)類(lèi)型是否是double型的:
- 如果想要以格式化的方式來(lái)查看文檔
db.集合名.find().pretty()- 普通格式:

- pretty格式:

- 普通格式:
- 更新文檔:
- 更新文檔可以使用下面幾個(gè):
db.集合名.updateOne(<query>,<update>,{option}):更新單條文檔db.集合名.updateMany(<query>,<update>,{option}):更新多條文檔db.集合名.update(<query>,<update>,{option}):更新文檔,可選單條文檔或多條文檔
query是BSON格式的,作為查找文檔的條件,query的條件參考上面查找文檔中的query filterupdate是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í)別。

- 更新文檔可以使用下面幾個(gè):
刪除數(shù)據(jù):db.集合名.remove(query):刪除所有符合條件的文檔- query :刪除的文檔的條件。如果條件為{},則刪除所有文檔
,query可以參考查找文檔中的query filter - justOne : (可選)如果設(shè)為 true 或 1,則只刪除一個(gè)文檔。
- writeConcern :(可選)拋出異常的級(jí)別。
- query :刪除的文檔的條件。如果條件為{},則刪除所有文檔
想了解更多可以參考官方文檔。https://docs.mongodb.com/manual/reference/bson-types/

希望本文所述對(duì)大家MongoDB數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。
相關(guān)文章
MongoDB自動(dòng)刪除過(guò)期數(shù)據(jù)的方法(TTL索引)
這篇文章主要給大家介紹了關(guān)于MongoDB自動(dòng)刪除過(guò)期數(shù)據(jù)(TTL索引)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
MongoDB利用oplog恢復(fù)數(shù)據(jù)的方法
這篇文章主要介紹了MongoDB利用oplog恢復(fù)數(shù)據(jù)的方法,當(dāng)我們對(duì)數(shù)據(jù)出現(xiàn)誤操作的時(shí)候,可以利用oplog恢復(fù)數(shù)據(jù),下文操作過(guò)程需要的小伙伴可以參考一下2022-04-04
MongoDB數(shù)據(jù)庫(kù)中索引和explain的使用教程
這篇文章主要給大家介紹了關(guān)于MongoDB數(shù)據(jù)庫(kù)中索引和explain使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Mongodb具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08
MongoDB增刪查改操作示例【基于JavaScript Shell】
這篇文章主要介紹了MongoDB增刪查改操作,結(jié)合實(shí)例形式分析了MongoDB數(shù)據(jù)庫(kù)基于JavaScript Shell的基本增刪查改操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2019-07-07
在 Fedora 上安裝 MongoDB 服務(wù)器的方法教程
Mongo是一個(gè)高性能、開(kāi)源、無(wú)模式的、面向文檔的數(shù)據(jù)庫(kù),它是最受歡迎的 NoSQL 數(shù)據(jù)庫(kù)之一。這篇文章主要介紹了在 Fedora 上安裝 MongoDB 服務(wù)器的方法,需要的朋友可以參考下2020-03-03
MongoDB的Master-Slave主從模式配置及主從復(fù)制要點(diǎn)解析
主從復(fù)制是數(shù)據(jù)庫(kù)運(yùn)維中一種常見(jiàn)的備份方式,這里我們來(lái)看一下MongoDB的Master-Slave主從模式配置及主從復(fù)制要點(diǎn)解析,需要的朋友可以參考下2016-06-06




