Mongodb經常使用操做

mongodb使用python

安裝mongodb,並啓動mongodb後,基本操做:mysql

show dbs; 顯示數據庫
show collections;顯示當前數據庫中的集合,相似mysql中數據庫的表
show users; 顯示用戶
use <db name> 切換當前數據庫,與mysql中同樣

數據庫經常使用命令:正則表達式

MongoDB沒有建立數據庫的命令,但有相似的命令,先運行use <db name> 命令,以後就作一些操做,如db.createCollection('user'),這樣就能夠建立一個數據庫了。

刪除當前使用的數據庫: db.dropDatabase();

從指定的主機上克隆數據庫: db.cloneDatabase('hostname/ip');
	
從指定的機器上覆制指定的數據庫到某個數據庫 db.copyDatabase('mydb','temp','127.0.0.1:27017')

修復當前數據庫: db.repairDatabase();

查看當前使用的數據庫: db.getName() / db

顯示當前db狀態 db.stats()

當前db版本 db.version()

查看當前db的連接機器的地址 db.getMongo()

Collection集合經常使用命令:sql

建立一個集合: db.createCollection('name', {capped:<Boolean>,autoIndexId:<Boolean>,size:<number>,max:<number>})
    name:是集合的名字,
    capped: 是否啓用集合限制,若是啓用須要制定一個限制條件,默認不啓用,這個參數沒有實際意義
    size:限制集合使用空間的大小,默認沒有限制
    max:集合中最大條數限制,默認爲沒有限制
    autoIndexId: 是否使用id做爲索引,默認使用(true/false)
    size 的優先級比max高
好比:
    一、db.createCollection('log') 沒有任何的大小,數量限制,使用_id做爲默認索引
    二、限制集合空間的大小:db.createCollection('log',{size:1024}) 或db.createCollection('log',{capped:true,size:1024}),限制空間大小爲1M,若是超出1M,則會刪除最先的記錄
    三、限制集合的最大條數: db.createCollection('log',{max:1024}),建立一個名字爲log集合,最大條數爲1024,超過則會刪除最先的一條記錄,這個不能使用capped:true,不然會報錯
    四、限制最大條數有限制使用空間大小,db.createCollection('log',{size:1024,max:1024})或 db.createCollection('log',{capped:true,size:1024,max:1024}) 限制集合最大使用空間爲1M,最大條數爲1024條
    
獲得指定名稱的集合 db.getCollection('one')

獲得當前db的全部集合 db.getCollectionNames()

顯示當前db全部集合索引的狀態 db.printCollectionStats()

用戶相關相關操做:mongodb

Mongodb用戶和認證 權限總結:
新安裝mongodb後開啓MongoDB服務時不添加任何參數時,默認是沒有權限驗證的,登陸的用戶能夠對數據庫任意操做並且能夠遠程訪問數據庫。此時,mongodb默認有一個admin數據庫,而且是空的,沒有記錄權限相關的信息。當admin.system.users一個用戶都沒有時,即便mongodb啓動時添加了--auth參數,若是沒有在admin數據庫中添加用戶,此時不進行任何認證仍是能夠作任何操做。直到admin.system.users中添加了一個用戶。
須要注意的是:admin.system.users中將會保存比在其它數據庫中設置的用戶權限更大的用戶信息,擁有超級權限,也就是說在admin中建立的用戶能夠對mongodb中的其餘數據庫數據進行操做。

一、mongodb系統中,數據庫是由超級用戶來建立的,一個數據庫能夠包含多個用戶,一個用戶只能在一個數據庫下,不一樣數據庫中的用戶能夠同名!
二、當admin.system.users一個用戶都沒有時,即便mongod啓動時添加了--auth參數,若是沒有在admin數據庫中添加用戶,此時不進行任何認證仍是能夠作任何操做(不論是否是以--auth 參數啓動),直到在admin.system.users中添加了一個用戶。
三、特定數據庫好比DB1下的用戶User1,不可以訪問其餘數據庫DB2,可是能夠訪問本數據庫下其餘用戶建立的數據!
四、不一樣數據庫中同名的用戶不可以登陸其餘數據庫!好比DB1,DB2都有user1,以user1登陸DB1後,不可以登陸到DB2進行數據庫操做!
五、在admin數據庫建立的用戶具備超級權限,能夠對mongodb系統內的任何數據庫的數據對象進行操做!

用戶相關命令操做:
shell

添加一個用戶:db.addUser('name')或 db.addUser('username','passwd123',true) 添加用戶,設置密碼,是否爲只讀,默認爲false
數據庫認證、安全模式  db.auth('username','passwd')
顯示當前全部用戶: show users;
刪除用戶: db.removeUser('username')

集合查詢:數據庫

查詢全部記錄:
db.userInfo.find() 至關於:select * from userInfo;
默認每頁顯示20條記錄,當顯示不下的狀況下,能夠用it迭代命令查詢下一頁,it後面不要加;能夠設置每頁顯示數據的大小,用DBQuery.shellBatchSize= 50;這樣每頁就顯示50條記錄了

查詢去掉集合中的某列的重複數據
db.userInfo.distinct('name')  至關於:select distict name from userInfo;

查詢age=xx的記錄
db.userInfo.find({'age':22})

查詢age>22的記錄:
db.userInfo.find({age:{$gt:22}})  至關於:select * from userInfo where age >22;

查詢age<22的記錄:
db.userInfo.find({age:{$lt:22}})

查詢age >= 25的記錄
db.userInfo.find({age:{$gte:25}})

查詢age <= 25的記錄
db.userInfo.find({age:{$lte:25}})

查詢age >= 23 而且 age <= 26
db.userInfo.find({age:{$gte:23,$lte:26}})

查詢name中包含mongo的數據
db.userInfo.find({name: /mongo/}) 至關於:select * from userInfo where name like ‘%mongo%’;

查詢name中以mongo開頭的
db.userInfo.find({name:/^mongo/}) 至關於:select * from userInfo where name like ‘mongo%’;

查詢指定列name,age數據:
db.userInfo.find({},{name:1,age:1}) 至關於:select name, age from userInfo;

固然name也能夠用true或false,當用true的狀況下,如例子同樣的效果,若是爲false就排除name,顯示name之外的列的信息。
查詢指定列name、age數據, age > 25
db.userInfo.find({age:{$gt:25}},{name:1,age:1})

查詢name = zhangsan, age = 22的數據
db.userInfo.find({name:'zhangsan',age:22})

查詢10條之後的數據
db.userInfo.find().skip(10)  至關於:select * from userInfo where id not in (selecttop 10 * from userInfo);

查詢在5-10之間的數據
db.userInfo.find().limt(10).skip(5)
可用於分頁,limit是pageSize,skip是第幾頁*pageSize

and 查詢
db.userInfo({'name':'hurry','age':18},{'name':1,'age':1}) 至關於:select name,age from userInfo  where name='hurry'

or與查詢
db.userInfo.find({$or: [{age:22},{age:25}]}) 至關於:select * from userInfo where age = 22 or age = 25;

使用in,not in ($in,$nin)
db.userInfo.find({'age':{$in:[10,22,26]}})  至關於:select * from users where age in (10, 22, 26);

與null匹配
db.userInfo.find({'age':null})

查詢第一條數據:
db.userInfo.findOne() 至關於:selecttop 1 * from userInfo;
或:db.userInfo.find().limit(1)

查詢某個結果集的記錄條數:
db.userInfo.find({age:{$gte:25}}).count() 至關於:select count(*) from userInfo where age >= 25;

按照某列進行求和:
db.userInfo.find({sex:{$exists:true}}).count() 至關於select count(sex) from userInfo;
大於,小於,大於或等於,小於或等於
$gt:大於
$lt:小於
$gte:大於或等於
$lte:小於或等於

不等於:$ne

取模運算:$mod
db.userInfo.find({'a':{$mod:[10,1]}})

$all
$all 與$in相似,可是他須要匹配條件內全部的值:
如一個對象:{a:[1,2,3]}
這個條件能夠匹配:db.userInfo.find(a:{$all:[2,3]})
可是這個條件就不行了,db.userInfo.find(a:{$all:[2,3,4]})

$size 是匹配數組內的元素數量的
如一個對像:{a:['foo']}
這個語句就能夠匹配:db.userInfo.find({a:{$size:1}})
官網上說不能用來匹配一個範圍內的元素,若是想找$size<5之類的,他們建議建立一個

$exists
$exists用來判斷一個元素是否存在
以下:
db.userInfo.find({a:{$exists:true}}) 若是存在a就返回
db.userInfo.find({a:{$exists:false}}) 若是不存在元素a 就返回

$not取反
db.userInfo.find({'name':{$not:/acme.*corp/i}})

$type
$type基於bson type來匹配一個元素的類型,像是按照ID來匹配,bson類型和id對照表:
類型描述 類型值

Doubleexpress

1
String 2
Object 3
Array 4
Binary data 5

Object idjson

7
Boolean 8
Date 9
Null 10
Regular expression  11

JavaScript code數組

13
Symbol 14
JavaScript code with scope 15
32-bit integer 16

Timestamp

17
64-bit integer 18

Min key

255
Max key 127

使用以下:

db.userInfo.find({a:{$type:2}}) 若是是字符串即:string就返回a
db.userInfo.find({a:{$type:16}}) 若是是int類型,就返回a

正則表達式

mongo支持正則表達式,如
db.userInfo.find({name:/acme.*corp/i}) 後面i的意思是區分大小寫

索引:

建立索引:
db.userInfo.ensureIndex({name:1})
db.userInfo.ensureIndex({name:1,ts:-1})
查詢當前集合全部索引:
db.userInfo.getIndexes()
查看總索引記錄大小
db.userInfo.totalIndexSize()
讀取當前集合全部index信息
db.userInfo.reIndex()
刪除指定索引:
db.userInfo.dropIndex("name_1")
刪除全部索引
db.userInfo.dropIndexes()

添加:

db.userInfo.save({'name':'zhangsan','age':25,sex:true})
添加的數據的數據列,沒有固定,根據添加的數據爲準

修改:

db.userInfo.update({age:25},{$set:{name:'lisi'}},false,true)
至關於:update users set name = ‘changeName’ where age = 25;
db.userInfo.update({name:'lisi'},{$inc:{age:50}},false,true)
至關於:update users set age = age + 50 where name = ‘lisi’;
db.userInfo.update({'name':'lisi'},{$inc:{'age':50},$set:{name:'hoho'}},false,true)

刪除:

db.userInfo.remove({'age': 132})

查詢修改刪除:

db.userInfo.findAndModify({
	query:{age:{$gte:25}},
	sort:{age:-1},
	update:{$set:{name:'a2'},
	$inc:{age:2}},
	remove:true})
db.runCommand({findandmodify:'usersInfo',
	query: {age:{$gte:25}},
	sort: {age:-1},
	update:{$set:{name:'a2'},$inc:{age:2}},
	remove:true})
update 或 remove 其中一個是必須的參數; 其餘參數可選。

排序:

升序:db.userInfo.find().sort({age:1})
降序:db.userInfo.find().sort({age:-1})

將一個對象轉換成json

tojson(new Object())
tojson(new Ojbect('a'))

循環添加數據:

> for (var i = 0; i < 30; i++) {
	db.userInfo.save({name:'u_' + i, age:22 + i,sex:i % 2})
	}
這樣就循環添加了30條數據,一樣也能夠省略括號的寫法
> for (var i = 0; i < 30; i++) {db.userInfo.save({name:'u_'+i,age:22+i,sex:i%2})}

find 遊標查詢

> var cursor = db.userInfo.find()
> while (cursor.hasNext()) {
	printjson(cursor.next())
	}

這樣就查詢全部的users信息,一樣能夠這樣寫
var cursor = db.users.find();
while (cursor.hasNext()) {printjson(cursor.next)}

forEach迭代循環

db.users.find().forEach(printjson)
forEach中必須傳遞一個函數來處理每條迭代的數據信息

將find遊標當數組處理

var cursor = db.users.find()
cursor[4]
取得下標索引爲4的那條數據
既然能夠當作數組處理,那麼就能夠得到它的長度:cursor.length();或者cursor.count();
那樣咱們也能夠用循環顯示數據
for (var i = 0 ,len = c.length(); i < len; i++) printjson(c[i])

將find遊標轉換成數組
>var arr = db.userInfo.find().toArray()
>printjson(arr[2])
用toArray方法將其轉換爲數組

其餘:

查詢以前的錯誤信息:db.getPrevError();
清除錯誤記錄:db.resetError()
相關文章
相關標籤/搜索