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

mongodb的安裝使用和pymongo基本使用教程

 更新時間:2017年07月18日 17:12:45   作者:PilgrimHui  
這篇文章主要介紹了mongodb的安裝使用和pymongo基本使用教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

(1) mongodb的安裝

下載tgz解壓后,需要添加相應(yīng)的環(huán)境變量才能在終端直接啟動mongod。

mongodb數(shù)據(jù)存儲在/data/db中,需要手動創(chuàng)建目錄樹,同時mongod執(zhí)行的時候如果權(quán)限不夠(不能往/data/db寫東西),需要改一下權(quán)限。

vim ~/.bashrc
export PATH="~/download/mongodb-linux-x86_64-ubuntu/bin:$PATH"
mkdir -p /data/db
ls -l / 查看data目錄的權(quán)限,發(fā)現(xiàn)擁有者可寫
ls -l /data 查看db目錄的權(quán)限,發(fā)現(xiàn)擁有者可寫
chown -R "liaohuqiang" /data data下的所有文件的擁有者改為自己 

(2) mongod的啟動

之后就可以在終端上輸入mongod,這個時候就啟動了mongodb,但是這個時候是在終端運行著的,相當(dāng)于一個前臺進程,在這個終端你不能做其它操作。

可以使用--fork選項,開啟后會回到終端交互,可以繼續(xù)做自己的事。

fork表示以守護進程的方式啟動mongodb,創(chuàng)建一個服務(wù)器進程。fork要配合logpath使用,表示日志信息輸出到哪個日志文件。logappend表示以追加的方式寫入日志文件。

當(dāng)然還有別的啟動方式,目前還沒用到,暫時先不說。

mongod --fork --logappend ~/mongo.log --logappend 

(3)mongo的使用

啟動mongod后就可以在終端進入mongo進行相關(guān)數(shù)據(jù)庫操作

show dbs 顯示所有數(shù)據(jù)庫
use doctor 切換到某個數(shù)據(jù)庫"doctor", 不切換的話默認使用test
db.dropDatabase() 刪除數(shù)據(jù)庫
show collections 顯示所有集合
db.sample.drop() 刪除集合
db.sample.insert({name:"pilgrimHui", label:"1"}) 插入一行記錄
db.sample.insert({...}) 如果文檔已存在,會更新_id,不存在則同insert
db.sample.find({...}) 查找滿足條件的記錄,簡單的一些查詢條件見下面
db.sample.find({...},{field1:1, field2:1}) 只找出某些字段
db.sample.find() 查找sample集合所有記錄
db.sample.remove({...},1) 刪除滿足條件的記錄,參數(shù)1可選,代表只刪除1個
db.sample.remove({}) 刪除sample集合的所有記錄

(4) mongo里的update操作

db.collection.update(criteria, objNew, upsert, multi)
criteria: 查詢條件,理解為sql update語句where后面的
objNew: 更新操作,理解為sql update語句set后面的
upsert: 如果不存在查詢到的記錄,是否插入。默認false,不插入
multi: 是否更新多條。默認false,只更新第一條。
# 例如:把集合里所有記錄的status改為0
db.sample.update({"status": {$ne: 0} }, {$set: {"status":0}}, {multi: true})
或者
db.sample.update({"status": {$ne: 0} }, {$set: {"status":0}}, false,true)

(4) 幾個查詢操作符

$ne 不等
$gt 大于
$gte 大于等于
$lt 小于
$lte 小于等于
$in和$nin 是否在指定數(shù)組中
$all 是否全在指定數(shù)組中
$or 將數(shù)組中的多個鍵值對或運算
$slice:[1,2] 切片,取屬性值(數(shù)組)的某幾個
$size 該屬性值(數(shù)組)的長度
$exists:true 選擇該字段存在的記錄
$not 對任何查詢操作符取非
$regex 使用正則表達式匹配

(5) 幾個更新操作符

{ $inc : { field : value } }
{ $set : { field : value } }
{ $unset : { field : 1} } 
{ $push : { field : value } } 追加,field要是數(shù)組
{ $pull : { field : value } } 和push相反
{ $pop : { field : 1 } } 刪除最后1個值
{ $pop : { field : -1 } } 刪除第1個值 
{ $currentDate: { <field1>: {$type:"date", ... } } 設(shè)定當(dāng)前時間
{ $rename: {<field1>:<newName1>,<field2>:<newName2>,...} } 重命名字段

(6) 用戶權(quán)限設(shè)置

mongodb默認沒有帳號登錄,需要自己先添加帳號。

在admin數(shù)據(jù)庫添加的帳號為管理員帳號,在其它數(shù)據(jù)庫添加的帳號為普通用戶

用戶只能在用戶所在的數(shù)據(jù)庫登錄,包括管理員。

管理員只能在admin登錄認證后才能管理其它數(shù)據(jù)庫。

6.1 添加管理員帳號

use admin
db.system.users.find()

db.addUser('liaohuqiang','liaohuqiang')  添加管理員用戶,mongodb版本不同,可能會報錯,如果報錯找不到addUser則

用下面這個

db.createUser(
 {
  user: 'liaohuqiang',
  pwd: 'liaohuqiang',
  roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
 }
)

6.2 重新啟動mongod

創(chuàng)建成功后重啟mongod,這個時候開啟連接可以帶上--auth選項,代表驗證用戶權(quán)限。

mongod --fork --logappend ~/mongo.log --logappend --auth

6.3 認證登錄

開啟后,直接mongo進去操作會受限,可以mongo連接時授權(quán)登錄;也可以連接進去后再認證。

mongo -u liaohuqiang -p --authenticationDatabase admin
mysql -h ip -u root -p 亂入,對比一下mysql的連接
mongo
use admin
db.auth('liaohuqiang', 'liaohuqiang')

6.4 關(guān)閉連接

認證登錄后就可以像之前那樣操作數(shù)據(jù)庫了,操作完后可以在admin數(shù)據(jù)庫關(guān)閉連接。

use admin 
db.shutdownServer() 關(guān)閉mongod 

(7) pymongo的連接

import pymongo
client=pymongo.MongoClient('mongodb://username:password@ip')
db=client['doctor']
users=db["user"]
result= list(users.find( {'role':1}, {'_id':0} ) ) 選多個
result= users.find_one({"name":name}) 選單個
users.insert_one({"name":name}) 插一個,會自動生成主鍵
users.remove( {"name":name}, {"multi":True} ) 刪多個
users.update_one({'name':name},{'$inc':{'commitCount':1}}) 改一個

總結(jié)

以上所述是小編給大家介紹的mongodb的安裝使用和pymongo基本使用教程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 基于Mongodb分布式鎖解決定時任務(wù)并發(fā)執(zhí)行問題

    基于Mongodb分布式鎖解決定時任務(wù)并發(fā)執(zhí)行問題

    這篇文章主要介紹了基于Mongodb分布式鎖解決定時任務(wù)并發(fā)執(zhí)行問題,網(wǎng)上有很多分布式鎖的實現(xiàn)方案,基于redis、zk、等有很多,但是我的就是一個用了mysql和mongo的小應(yīng)用,本文給大家詳細講解,需要的朋友可以參考下
    2023-04-04
  • 利用golang驅(qū)動操作MongoDB數(shù)據(jù)庫的步驟

    利用golang驅(qū)動操作MongoDB數(shù)據(jù)庫的步驟

    這篇文章主要給大家介紹了關(guān)于如何利用golang驅(qū)動操作MongoDB數(shù)據(jù)庫的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • MongoDB中4種日志的詳細介紹

    MongoDB中4種日志的詳細介紹

    這篇文章主要給大家介紹了關(guān)于MongoDB中4種日志的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 毫不費力!在Ubuntu上安裝MongoDB7.0的簡易指南!

    毫不費力!在Ubuntu上安裝MongoDB7.0的簡易指南!

    MongoDB是一種流行的NoSQL數(shù)據(jù)庫管理系統(tǒng),用于處理大量結(jié)構(gòu)化和半結(jié)構(gòu)化數(shù)據(jù),本文提供了在Ubuntu上安裝MongoDB?7.0的詳細步驟,以下步驟包含了在Ubuntu系統(tǒng)中安裝MongoDB的必要軟件包、配置MongoDB數(shù)據(jù)目錄、配置MongoDB數(shù)據(jù)庫的認證方式等信息,需要的朋友可以參考下
    2023-10-10
  • MongoDB數(shù)據(jù)庫查詢性能提高40倍的經(jīng)歷分享

    MongoDB數(shù)據(jù)庫查詢性能提高40倍的經(jīng)歷分享

    大家在使用 MongoDB 的時候有沒有碰到過性能問題呢?下面這篇文章主要給大家分享了MongoDB數(shù)據(jù)庫查詢性能提高40倍的經(jīng)歷,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • MongoDB4.2.5安裝方法操作步驟

    MongoDB4.2.5安裝方法操作步驟

    這篇文章主要介紹了MongoDB4.2.5安裝方法操作步驟,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • MongoDB中的主從同步配置和mongod相關(guān)啟動命令講解

    MongoDB中的主從同步配置和mongod相關(guān)啟動命令講解

    這篇文章主要介紹了MongoDB中的主從同步配置和mongod相關(guān)啟動命令講解,文中也羅列了很多其他常用的mongod命令參數(shù),需要的朋友可以參考下
    2016-03-03
  • MongoDB快速入門及其SpringBoot實戰(zhàn)教程

    MongoDB快速入門及其SpringBoot實戰(zhàn)教程

    MongoDB是一個開源、高性能、無模式的文檔型數(shù)據(jù)庫,當(dāng)初的設(shè)計就是用于簡化開發(fā)和方便擴展,是NoSQL數(shù)據(jù)庫產(chǎn)品中的一種,它支持的數(shù)據(jù)結(jié)構(gòu)非常松散,是一種類似于JSON的格式叫BSON,本文介紹MongoDB快速入門及其SpringBoot實戰(zhàn),感興趣的朋友一起看看吧
    2023-12-12
  • MongoDB Remove函數(shù)的3個常見用法

    MongoDB Remove函數(shù)的3個常見用法

    這篇文章主要介紹了MongoDB Remove函數(shù)的3個常見用法,需要的朋友可以參考下
    2014-05-05
  • 關(guān)于MongoDB謹防索引seek的效率問題詳析

    關(guān)于MongoDB謹防索引seek的效率問題詳析

    這篇文章主要給大家介紹了關(guān)于MongoDB謹防索引seek的效率問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11

最新評論