mongo shell
mongo 連接
本地
mongo # 連接127.0.0.1:27017
遠(yuǎn)程
mongo "mongodb://mongodb0.example.com:28015"
帶認(rèn)證的方式
mongo "mongodb://alice@mongodb0.examples.com:28015/?authSource=admin"
復(fù)制集
mongo "mongodb://mongodb0.example.com.local:27017,mongodb1.example.com.local:27017,mongodb2.example.com.local:27017/?replicaSet=replA"
mongo "mongodb+srv://server.example.com/" # DNS Seedlist Connection Format
SSL方式
mongo "mongodb://mongodb0.example.com.local:27017,mongodb1.example.com.local:27017,mongodb2.example.com.local:27017/?replicaSet=replA&ssl=true"
mongo shell 操作
db # 查看當(dāng)前數(shù)據(jù)庫(kù)
use <database> #使用數(shù)據(jù)庫(kù)
當(dāng)插入數(shù)據(jù)時(shí)會(huì)自動(dòng)創(chuàng)建集合
在mongo第一次顯示提示之前,會(huì)自動(dòng)運(yùn)行HOME 目錄下的.mongorc.js 文件,如果不想加載,可以使用--norc 參數(shù)
配置shell
cmdCount = 1;
prompt = function() {
return (cmdCount++) + "> ";
}
# 顯示行數(shù)
Date
- Date() 返回string
- new Date() 返回ISODate
- ISODate() 返回ISODate
ObjectId
_id的類型
NumberLong
mongo shell中,默認(rèn)認(rèn)為數(shù)字為浮點(diǎn)型,為表示64位int型數(shù)據(jù),可以用NumberLong
如果用$inc作用于NumberLone,將把此數(shù)轉(zhuǎn)為浮點(diǎn)型
數(shù)字比較
Query |
Results |
{ “val”: 9.99 } |
{ “_id”: 2, “val”: 9.99, “description”: “Double” } |
{ “val”: NumberDecimal( “9.99” ) } |
{ “_id”: 1, “val”: NumberDecimal( “9.99” ), “description”: “Decimal” } |
{ val: 10 } |
{ “_id”: 3, “val”: 10, “description”: “Double” }{ “_id”: 4, “val”: NumberLong(10), “description”: “Long” }{ “_id”: 5, “val”: NumberDecimal( “10.0” ), “description”: “Decimal” } |
{ val: NumberDecimal( “10” ) } |
{ “_id”: 3,“val”:10, “description”: “Double” }{ “_id”: 4, “val”: NumberLong(10), “description”: “Long” }{ “_id”: 5, “val”: NumberDecimal( “10.0” ), “description”: “Decimal” } |
當(dāng)double類型的數(shù)據(jù)進(jìn)行比較時(shí),會(huì)轉(zhuǎn)換double的數(shù)據(jù)類型為decimal,而且會(huì)有誤差
可以用type進(jìn)行比對(duì)
db.inventory.find( { price: { $type: "decimal" } } )
shell操作指南
~/.dbshell :操作 記錄
show dbs :查看 所有 數(shù)據(jù)庫(kù),不同的訪問(wèn)權(quán)限會(huì)有不同的結(jié)果
use <db> :使用數(shù)據(jù)庫(kù)
show collections :查看所有集合
show users :查看當(dāng)前所有用戶
show roles :查看當(dāng)前數(shù)據(jù)庫(kù)所有角色,包括內(nèi)建的
show profile :打印耗時(shí)1毫秒以上的操作5個(gè)
show databases :查看可訪問(wèn)的所有數(shù)據(jù)庫(kù)
|