MongoDB之基本操做與平常維護

MongoDB基本操做

MongoDB的基本操做主要是對數據庫、集合、文檔的操做,包括建立數據庫、刪除數據庫、插入文檔、更改文檔、刪除文檔、和查詢文檔。javascript

操做 描述
show dbs 查看當前實例下的數據庫列表
show users 顯示用戶
use <db_name> 切換當前數據庫
db.help() 顯示數據庫操做命令
show.collections 顯示當前數據庫中的集合
db.foo.help() 顯示集合操做命令,foo是當前數據庫下的集合
db.foo.find() 對當前數據庫中foo集合進行數據查找

MongoDB數據類型

  • MongoDB支持許多數據類型的列表下面給出:
  • String : 這是最經常使用的數據類型來存儲數據。在MongoDB中的字符串必須是有效的UTF-8。
  • Integer : 這種類型是用來存儲一個數值。整數能夠是32位或64位,這取決於您的服務器。
  • Boolean : 此類型用於存儲一個布爾值 (true/ false) 。
  • Double : 這種類型是用來存儲浮點值。
  • Min/ Max keys : 這種類型被用來對BSON元素的最低和最高值比較。
  • Arrays : 使用此類型的數組或列表或多個值存儲到一個鍵。
  • Timestamp : 時間戳。這能夠方便記錄時的文件已被修改或添加。
  • Object : 此數據類型用於嵌入式的文件。
  • Null : 這種類型是用來存儲一個Null值。
  • Symbol : 此數據類型用於字符串相同,但它一般是保留給特定符號類型的語言使用。
  • Date : 此數據類型用於存儲當前日期或時間的UNIX時間格式。能夠指定本身的日期和時間,日期和年,月,日到建立對象。
  • Object ID : 此數據類型用於存儲文檔的ID。
  • Binary data : 此數據類型用於存儲二進制數據。
  • Code : 此數據類型用於存儲到文檔中的JavaScript代碼。
  • Regular expression : 此數據類型用於存儲正則表
#建立數據庫testdb數據庫,使用如下語句 mongos> use testdb; #查詢數據庫,要顯示數據庫必須插入至少一條文檔 mongos> show dbs; #插入數據文檔 mongos> db.tablename.insert({"name":"antian"}); #數據庫生成了 mongos> show dbs; testdb 0.078GB  #查詢數據庫 mongos> show dbs; testdb 0.078GB #進入數據庫 mongos> use testdb; #刪除數據庫 mongos> db.dropDatabase(); { "dropped" : "testdb", "ok" : 1 } #查詢數據庫 mongos> show dbs;
#建立集合 #進入數據庫 mongos> use testdb; #建立集合 mongos> db.createCollection("mycollection") mongos> show tables; mycollection  #刪除集合 #進入數據庫 mongos> use testdb; mongos> show tables; mycollection mongos> db.mycollection.drop(); true mongos> show tables;
#插入文檔 #插入一條文檔 mongos> db.tablesname.insert([{"name":"aaaaa","age":"18"} #插入兩條文檔 mongos> db.tablesname.insert([{"name":"ddddd","age":"18"},{"name":"eeee","age":"10"}]); #查詢一個文檔: mongos> db.tablesname.findOne();

MongoDB平常維護

一.導入導出

mongoimport命令能夠把一個特定格式文件中的內容導入到指定的collection中。該工具能夠導入JSON格式數據,也能夠導入CSV格式的數據。 
mongoexport命令能夠把一個collection導出成JSON格式或CSV格式的文件。能夠經過參數指定導出的數據項,也能夠根據指定的條件導出數據。 
參數說明:java

  • -d:指明數據庫的名字
  • -c:指明collection的名字
  • -f:指明要導出哪些列
  • -o:指明要導出的文件名
  • -q:指明導出數據的過濾條件
for(var i=1;i<=100;i++)db.info.insert({"id":i,"name":"jack"+i}) //循環寫入100條數據 mongoexport -d school -c info -o /opt/info.json //導出 mongoimport -d school -c info1 --file /opt/info.json //導入到info集合 mongoexport -d school -c info1 -q '{"id":{"$eq":10}}' -o /opt/top10.json //條件導出指定第10行

二.備份與恢復

備份:mongodump 
恢復:mongorestore
 
參數說明:mongodb

  • -h: MongoDB所在服務器地址
  • -d:須要備份的數據庫實例
  • -o:備份的數據存放的位置,該目錄須要提早創建,在備份完成後,系統自動在dump目錄下創建一個test目錄,這個目錄裏面存放該數據庫實例的備份數據。
mkdir /backup   //建立存放目錄 mongodump -d abc -o /backup/ //備份abc數據庫 mongorestore -d abc123 --dir=/backup/abc //恢復到abc123數據庫

三.複製數據庫

db.copyDatabaseshell

>db.copyDatabase("abc","abc1") //複製數據庫abc生成abc1

四.克隆集合

runCommand
將abc中的info集合克隆到實例2數據庫

mongo --port 27018 //進入實例2 db.runCommand({"cloneCollection":"abc.info","from":"192.168.100.152:27017"})

五.受權啓動

能夠配置受權用戶來訪問MongoDB,啓動時必須指定auth=true,不然受權不起做用。 
能夠將用戶加入到角色,內置數據庫用戶角色包括:read、readWrite,數據庫管理角色包括:dbAdmin、dbOwner、useAdmin,超級用戶角色爲root。
express

vim /usr/bin/mongodb1.conf
......
auth=true
......
mongo
>use admin >db.createUser({"zx":"root","pwd":"123","roles":"[root"]}) //建立用戶zx,密碼爲123,分配到root角色 >db.auth("root","123") //驗證用戶

六.進程管理

  • 查看當前正在運行的進程的命令爲:db.currentOp()
  • 終止正在運行的高消耗資源的進程命令爲:db.killOp(opid)

七.MongoDB監控

  • 查看數據庫實例的狀態信息:db.serverStatus()
  • 查看當前數據庫的統計信息:db.status()
  • 查看集合統計信息:db.users.stats()
  • 查看集合大小:db.users.dataSize()
  • 也能夠經過Web界面查看系統監控信息,須要在配置文件中添加下面一行: 
    httpinterface=true

而後在瀏覽器中經過http://localhost:28017 進行訪問。經過Web頁面能夠看到:json

    • 當前MongoDB的全部鏈接
    • 各個數據庫和Collection的訪問統計,包括:Reads、Writes、Queries、GetMores、Inserts、Updates、Removes。
    • 寫鎖的狀態
    • 日誌文件的最後幾百行。
    • 全部的MongoDB命令。
相關文章
相關標籤/搜索