1. 程式人生 > >Mongodb的筆記(安裝,Python操作,Robo3t操作)

Mongodb的筆記(安裝,Python操作,Robo3t操作)

安裝Mongodb(Centos7)

  1. 官網上找到需要下載的版本壓縮包進行下載。官網連結

    或者在命令列下使用wget命令進行下載

    
    # 這裡下載的是3.4.10版本
    
    wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.4.10.tgz
  2. 進行解壓縮

    
    # 解壓縮
    
    tar -zxvf mongodb-linux-x86_64*.tgz
    
    # 重新命名
    
    mv mongodb-linux-x86_64* mongodb
    
    # 移動到你想放置的目錄下,這裡我放在/opt目錄下
    
    mv mongodb /opt/
  3. 進行相應的配置,mongodb預設沒有任何配置

    
    # 進行mongodb主目錄
    
    cd /opt/
    
    # 建立存放資料檔案和日誌檔案的目錄
    
    mkdir -p data/test/logs
    mkdir -p data/test/db
    
    # 建立配置檔案,並寫入如下配置
    
    vim bin/mongodb.conf
     `
       # 設定資料檔案的存放目錄
       dbpath = /opt/mongodb/data/test/db
    
       # 設定日誌檔案的存放目錄及其日誌檔名
       logpath = /opt/mongodb/data/test/logs/mongodb.log
    
       # 設定埠號(預設的埠號是27017,可以根據個人需求進行更改)
       port = 27017
    # 設定為以守護程序的方式執行,即在後臺執行 fork = true # 是否不允許表掃描 nohttpinterface = true ` # 儲存退出
  4. 啟動mongodb

# 以配置檔案的方式啟動
./bin/mongod --config mongodb.conf

報錯一: ERROR: child process failed, exited with error number 1
檢查mongodb.conf的檔案路徑是否配置錯誤

報錯二:ERROR: child process failed, exited with error number 100


很可能是沒有正常關閉導致的,那麼可以刪除 mongod.lock檔案,這裡對應我的配置路徑在data/裡面

  1. 其他
# 連結命令,方便呼叫mongo命令
ln -s /opt/mongodb/bin/mongo /usr/bin
# 檢視mongodb程序
ps -aux |grep mongodb
# 檢查埠執行情況
netstat -lanp | grep 27017
# 終止mongodb服務,PID從ps命令獲取
kill -15 PID
# 新增自啟動命令
vim /etc/rc.local
# 末尾追加一行
`/opt/mongodb/bin/mongod --config mongodb.conf`
# 儲存退出
  1. 設定密碼許可權,預設無密碼
# 進行mongodb的互動環境
./mongo
# 如果進入失敗,請檢查是否添加了軟連結和是否啟動了mongodb服務

# 進行admin資料庫,建立管理員使用者root,密碼為password,許可權是超級使用者(最高)
>use admin
>db.createUser({user:"root",pwd:"password",roles:["root"]})
# 驗證是否建立成功,返回1表示成功
>db.auth({"root", "password"})
# 退出互動環境
>exit
# 重啟mongodb服務
# 殺死mongodb程序,參照上面的方法
# 以密碼許可權驗證啟動服務
opt/mongodb/mongod --config mongodb.conf --auth

資料庫許可權說明表

名稱 許可權
資料庫使用者角色 read、readWrite
資料庫管理角色 dbAdmin、dbOwner、userAdmin
叢集管理角色 clusterAdmin、clusterManager、clusterMonitor、hostManager
備份恢復角色 backup、restore
所有資料庫角色 readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
超級使用者角色 root
提供了系統超級使用者的訪問 dbOwner 、userAdmin、userAdminAnyDatabase
內部角色 __system

使用Python連線Mongodb

# 下載第三方包
pip3 install pymongo
# /usr/bin/python3
from pymongo import MongoClient

# 方法一
# host主機名,27017連線埠
client = MongoClient(host, 27017)
db_auth = client.admin
# 登陸的使用者名稱(username)和密碼(password)
db_auth.authenticate(username, password)
# 連線指定資料庫,資料庫名為db_name
db_name = client["db_name"]

# 方法二
# 使用者名稱(username)、密碼(password)、主機名(host)、埠(port)。注:這裡的password不能出現@符號,如果用@符號就需要使用方法一
client = MongoClient("mongodb://username:[email protected]:port")
# 連線指定資料庫,資料庫名為db_name
db_name = client["db_name"]

# 操作資料庫,db_name["db_set"]=db_name.db_set
"""
查詢資料
在db_name資料庫中的db_set集合裡面找到name是a_name的json
find是返回一個指標(可以使用列表的方式來讀取),find_one返回一個dict
"""
db_name["db_set"].find_one({"name": "a_name"})


# 插入資料
# 插入一個json到set1集合中,a_dict是一個字典(如果set1不存在則會被自動建立)
db_name.set1.insert_one(a_dict)
# 插入多個json到set1集合中,a_dict_lst是一個列表,裡面的元素是由字典組成的
db_name.set1.insert_many(a_dict_lst)

# 更新資料
# 查詢到一個數據之後,對裡面的某個資料進行更改,再使用save方法儲存
data_one = db_name["db_set"].find_one({"name": "a_name"}) 
data_one['age'] += 3 
db_name.db_set.save(data_one)
# 更新多條記錄,找到db_set集合中滿足age=20,sex=0的資料,將name改為user1
db_name.db_set.update({"name": "user1"}, {"$set":{"age": 20, "sex": 0}})

# 刪除資料
id = db_name.db_set.find_one({"name": "user1"})["_id"] 
# 根據 id 刪除一條記錄 
db_name.db_set.remove(id) 
# 刪除集合裡的所有記錄 
db_name.db_set.remove() 
# 刪除name=user1的記錄
db_name.db_set.remove({"name": "user1"}) 

視覺化Mongodb的操作

強烈推薦Robo 3t,官網地址

  1. 到官網找到對應的系統版本進行下載

  2. 安裝

    • Windows的安裝十分簡單就不贅述了

    • Ubuntu的安裝

      
      # 解壓縮
      
      tar -zxzf robomongo*.tar.gz
      
      # 修改檔名(可選)
      
      mv robomongo* robo3t
      
      # 移動到/opt目錄(可選)
      
      mv robo3t /opt
      
      # 建立軟連結
      
      ln -s /opt/robo3t/robomongo /usr/bin
      
      # 啟動
      
      robomongo
      
      # 如果報如下錯誤
      
      `
      This application failed to start because it could not find or load the Qt platform plugin "xcb" in "".
      
      Available platform plugins are: xcb.
      
      Reinstalling the application may fix this problem.
      Aborted (core dumped)
      `
      
      # 解決辦法
      
      mkdir ~/robo-backup
      mv /opt/robo3t/lib/libstdc++* ~/robo-backup/
      
      # 之後便可以重新啟動mongo試試看了
      
  3. 使用

    1. 首先建立新的連線,如下圖所示。在Connection中,``Name為自定義連線名,Address填入對應的hostport
      pic1
    2. Authentication中,勾選Perform authentication,填上對應的User NamePassword。填寫完成之後可以點選Test驗證是否能夠連線成功,如果無誤的話,可以點選Save儲存退出。

    pic2

    1. 連線Mongodb。點選Connect,之後就可以視覺化資料庫中的資料。也可以使用滑鼠簡單的進行建立/刪除資料庫,新建/修改資訊,也可以使用命令查詢資料。

進階操作

例子:

# test_db
{
     "_id" : ObjectId("56063f17ade2f21f36b03133"),
     "title" : "MongoDB 教程",
     "description" : "MongoDB 是一個 Nosql 資料庫",
     "by" : "菜鳥教程",
     "url" : "http://www.runoob.com",
     "tags" : [
             "mongodb",
             "database",
             "NoSQL"
     ],
     "links" : [{
           "UserName" : "@a1bf7a55ad8478017b95124774687769",
           "Uin" : 12266535,
           "NickName" : "一二三",
       }, 
       {
           "UserName" : "@5571e120b5d8f54f93338c76f62b9c419b818c29373dca9f331c2911a203bfbe",
           "Uin" : NumberLong(3379331828),
           "NickName" : "靈靈八",
       }]
}
# 返回查詢結果的數目
db.test_db.find({"title": "MongoDB 教程"}).count()
# 查詢某個key中的陣列是否某包含某內容
db.test_db.find({"tags": {"$in": ["mongodb"]}})
# 使用正則進行查詢
db.test_db.find({"url": {"$regex": "^http"}})
# 查詢某個由陣列構成的key方法
db.test_db.find({"links":{"$elemMatch":{"Uin":12266535,"NickName":"一二三"}}})