成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫 > MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)

MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)

熱門標(biāo)簽:智能電銷機(jī)器人銷售話術(shù) 徐州ai電銷機(jī)器人原理 沈陽營銷電銷機(jī)器人招商 高德地圖標(biāo)注商戶位置 南京400電話怎樣辦理 企業(yè)智能外呼系統(tǒng)價(jià)格多少 機(jī)器人外呼系統(tǒng)軟件存在問題 福州電銷機(jī)器人源代碼 兗州電話外呼營銷系統(tǒng)

一、安裝和配置
 
MongoDB 的官方下載站是 http://www.mongodb.org/downloads,可以去上面下載最新的安裝程序
 
Windows 平臺(tái)的安裝
 
● 步驟一: 下載 MongoDB
    點(diǎn)擊上方官方下載地址, 并下載 Windows 版本

● 步驟二: 設(shè)置 MongoDB 程序存放目錄
    下載完成后, 解壓到自定義文件夾,例: D:\mongodb\

● 步驟三: 設(shè)置數(shù)據(jù)文件存放目錄
    在 D:\mongodb\ 目錄下創(chuàng)建 db 和 logs 文件夾 (和 bin 目錄同級(jí)),
    隨后在 logs 文件夾內(nèi)創(chuàng)建 mongodb.log 日志文件

● 步驟四: 啟動(dòng) MongoDB 服務(wù), 作為 Windows 服務(wù)

復(fù)制代碼 代碼如下:

//進(jìn)入 cmd 控制臺(tái)
D:/mongodb/bin>mongod.exe --logpath D:/mongodb/logs/mongodb.log --logappend
                          --dbpath D:/mongodb/db
                          --directoryperdb
                          --serviceName MongoDB
                          --install
--directoryperdb 指定每個(gè)DB都會(huì)新建一個(gè)目錄

安裝完成后,就可以在 cmd 下用命令 net start MongoDB 和 net stop MongoDB 來啟動(dòng)和停止 MongoDB 了
 
● 步驟五: 客戶端連接驗(yàn)證
    打開 cmd 輸入: D:/mongodb/bin>mongo.exe
復(fù)制代碼 代碼如下:

D:/mongodb/bin>mongo.exe
MongoDB shell version: 2.4.8
connecting to: test
>

 
Linux 平臺(tái)的安裝
 
● 步驟一: 下載 MongoDB
    點(diǎn)擊上方官方下載地址, 并下載 Linux 版本

● 步驟二: 設(shè)置 MongoDB 程序存放目錄
    下載完成后, 解壓到自定義文件夾,例: /usr/local/mongo

● 步驟三: 設(shè)置數(shù)據(jù)文件存放目錄
    創(chuàng)建 /data/db 和 /data/logs 文件夾, 隨后在 logs 文件夾內(nèi)創(chuàng)建 mongodb.log 日志文件

● 步驟四: 啟動(dòng) MongoDB 服務(wù), 作為 Linux 服務(wù)隨機(jī)啟動(dòng)

復(fù)制代碼 代碼如下:

vi /etc/rc.local //使用vi 編輯器打開配置文件,并在其中加入下面一行代碼
 
/usr/local/mongo/bin/mongod --dbpath=/data/db/ --logpath=/data/logs/mongodb.log --logappend 

安裝完成后, 可以使用 pkill mongod 來結(jié)束
 
二、數(shù)據(jù)邏輯結(jié)構(gòu)
 
● MongoDB 的文檔(document),相當(dāng)于關(guān)系數(shù)據(jù)庫中的一行記錄。
● 多個(gè)文檔組成一個(gè)集合(collection),相當(dāng)于關(guān)系數(shù)據(jù)庫的表。
● 多個(gè)集合(collection),邏輯上組織在一起,就是數(shù)據(jù)庫(database)。
● 一個(gè) MongoDB 實(shí)例支持多個(gè)數(shù)據(jù)庫(database)。
● 默認(rèn)端口: 27017
 
三、常用命令
 
選擇數(shù)據(jù)庫
復(fù)制代碼 代碼如下:
use persons

顯示當(dāng)前數(shù)據(jù)庫
復(fù)制代碼 代碼如下:
db  ||  db.getName()

刪除當(dāng)前數(shù)據(jù)庫
復(fù)制代碼 代碼如下:
db.dropDatabase()

顯示當(dāng)前數(shù)據(jù)庫下的集合 Collections
復(fù)制代碼 代碼如下:

show tables || show collections

顯示當(dāng)前 system.profile
復(fù)制代碼 代碼如下:

show profile

顯示當(dāng)前數(shù)據(jù)庫下的用戶 Users
復(fù)制代碼 代碼如下:

show users

添加用戶
復(fù)制代碼 代碼如下:

db.addUser(username, password)

刪除用戶
復(fù)制代碼 代碼如下:

db.removeUser(username)

四、索引 ensureIndex()

復(fù)制代碼 代碼如下:

//普通索引
db.persons.ensureIndex({name:1});
 
db.factories.insert({name: "xyz", metro: {city: "New York", state: "NY"}});
//文檔式索引
db.factories.ensureIndex({metro : 1});
 
//嵌入式索引
db.factories.ensureIndex({"metro.city": 1});
 
//組合索引
db.things.ensureIndex({name: -1, qty: 1});
 
//唯一索引
db.user.ensureIndex({firstname: 1, lastname: 1}, {unique: true});
 
/* 當(dāng)一個(gè)記錄被插入到唯一性索引文檔時(shí),缺失的字段會(huì)以null為默認(rèn)值被插入文檔 */
db.things.save({lastname: "Smith"});
//下面這個(gè)操作將會(huì)失敗,因?yàn)?firstname 上有唯一性索引,值為 null
db.things.save({lastname: "Jones"});
 
//查看索引
db.persons.getIndexes();
 
//刪除所有索引
db.collection.dropIndexes();
 
//刪除單個(gè)索引
db.collection.dropIndex({x: 1, y: -1});

五、增刪改查等

復(fù)制代碼 代碼如下:

//定義文檔
>doc = {
    "_id"      : 1,
    "author"   : "sam",
    "title"    : "i love you",
    "text"     : "this is a test",
    "tags"     : [ "love", "test" ],
    "comments" : [
                   { "author" : "jim", "comment" : "yes" },
                   { "author" : "tom", "comment" : "no" }
                 ]
}
 
//插入文檔
> db.posts.insert(doc);
 
//查找文檔
> db.posts.find({'comments.author':'jim'});

查詢 Query

復(fù)制代碼 代碼如下:
//查詢集合中的所有記錄:
db.users.find({})
 
//查詢出所有 “l(fā)ast_name” 屬性值為 “Smith” 的文檔記錄
db.users.find({'last_name': 'Smith'})

 
查詢選項(xiàng)
復(fù)制代碼 代碼如下:
//返回除了 age 字段外的所有字段
> db.user.find( {},{ age : 0 } );
 
//返回 tags=tennis 除了 comments 的所有列
> db.posts.find( { tags : 'tennis' }, { comments : 0 } );
 
//返回 userid=16 的 name 字段
> db.user.find( { userid : 16 },{ name : 1 } );
//返回結(jié)果:
{ "_id" : 16, "name" : "user16" }
 
//返回 x=john 的所有 z 字段
> db.things.find( { x : "john" }, { z : 1 } );
 
//注: _id字段始終都會(huì)被返回,哪怕沒有明確指定

 
條件表達(dá)式
 
1) , =, >, >=
復(fù)制代碼 代碼如下:

// 大于: field > value
> db.collection.find( { "field" : { $gt : value } } );
 
//小于:field value
> db.collection.find( { "field" : { $lt : value } } );
 
//大于等于: field >= value
> db.collection.find( { "field" : { $gte : value } } );
 
//小于等于:field = value
> db.collection.find( { "field" : { $lte : value } } );
 
//區(qū)間查詢  5 field = 10
> db.collection.find( { "field" : { $gt : 5, $lte : 10 } } );

$all 操作類似 $in 操作,但是不同的是,$all操作要求數(shù)組里面的值全部被包含在返回的記錄里面
復(fù)制代碼 代碼如下:
> use test;
switched to db test
> db.things.insert( { a : [ 1, 2, 3 ] } );
 
> db.things.find();
{ "_id" : ObjectId("4de73360059e7f4bdf907cfe"), "a" : [ 1, 2, 3 ] }
 
> db.things.find( { a : { $all : [ 2, 3 ] } } );
{ "_id" : ObjectId("4de73360059e7f4bdf907cfe"), "a" : [ 1, 2, 3 ] }
 
> db.things.find( { a : { $all : [ 1, 2, 3 ] } } );
{ "_id" : ObjectId("4de73360059e7f4bdf907cfe"), "a" : [ 1, 2, 3 ] }
 
> db.things.find( { a : { $all : [ 1 ] } } );
{ "_id" : ObjectId("4de73360059e7f4bdf907cfe"), "a" : [ 1, 2, 3 ] }
 
> db.things.find( { a : { $all : [ 1, 2, 3, 4 ] } } );
>
>

$exists 操作檢查一個(gè)字段是否存在
復(fù)制代碼 代碼如下:

//userid 字段存在
> db.user.find( { userid : { $exists : true } } ).limit(1);
{ "_id" : 1, "name" : "user1", "userid" : 1, "age" : 20 }
//sex 字段不存在
> db.user.find( { sex : { $exists : true } } ).limit(1);
>
>

 
$mod 操作可以讓我們簡單的進(jìn)行取模操作
復(fù)制代碼 代碼如下:
//where子句
> db.user.find( "this._id%10==1" ).limit(5);
 
//$mod操作
> db.user.find( { _id : { $mod : [ 10, 1 ] } } ).limit(5);

$ne 意思是 不等于 (not equal)
復(fù)制代碼 代碼如下:
> db.user.find().limit(2);
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 20 }
{ "_id" : 1, "name" : "user1", "userid" : 1, "age" : 20 }
 
> db.user.find( { _id : { $ne : 0 } } ).limit(2);
{ "_id" : 1, "name" : "user1", "userid" : 1, "age" : 20 }

$in 操作類似于傳統(tǒng)關(guān)系數(shù)據(jù)庫中的IN
復(fù)制代碼 代碼如下:
//數(shù)據(jù)庫中有所有數(shù)組對(duì)應(yīng)的記錄
> db.user.find( { _id : { $in : [ 2, 3 ] } } ).limit(5);
{ "_id" : 2, "name" : "user2", "userid" : 2, "age" : 20 }
{ "_id" : 3, "name" : "user3", "userid" : 3, "age" : 20 }

$nin 跟 $in 操作相反
復(fù)制代碼 代碼如下:

//扣掉 _id = 1/2/3/4 的記錄
> db.user.find( { _id : { $nin : [ 1, 2, 3, 4 ] } } ).limit(5);
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 20 }
{ "_id" : 5, "name" : "user5", "userid" : 5, "age" : 20 }
{ "_id" : 6, "name" : "user6", "userid" : 6, "age" : 20 }

$or
復(fù)制代碼 代碼如下:
> db.user.find( { $or : [ { _id : 2 }, { name : 'user3' }, { userid : 4 } ] } ).limit(5);
{ "_id" : 2, "name" : "user2", "userid" : 2, "age" : 20 }
{ "_id" : 3, "name" : "user3", "userid" : 3, "age" : 20 }
{ "_id" : 4, "name" : "user4", "userid" : 4, "age" : 20 }
>

$nor 跟 $or 相反
復(fù)制代碼 代碼如下:
> db.user.find( { $nor : [ { _id : 2 }, { name : 'user3' }, { userid : 4 } ] } ).limit(4);
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 20 }
{ "_id" : 1, "name" : "user1", "userid" : 1, "age" : 20 }
{ "_id" : 5, "name" : "user5", "userid" : 5, "age" : 20 }
{ "_id" : 6, "name" : "user6", "userid" : 6, "age" : 20 }
>

$size 操作將會(huì)查詢數(shù)組長度等于輸入?yún)?shù)的數(shù)組
復(fù)制代碼 代碼如下:
> db.things.find();
{ "_id" : ObjectId("4de73360059e7f4bdf907cfe"), "a" : [ 1, 2, 3 ] }
 
> db.things.find( { a : { $size : 3 } } );
{ "_id" : ObjectId("4de73360059e7f4bdf907cfe"), "a" : [ 1, 2, 3 ] }
 
> db.things.find( { a : { $size : 2 } } );
>
> db.things.find( { a : { $size : 1 } } );
>

$where
復(fù)制代碼 代碼如下:
> db.mycollection.find( { $where : function() { return this.a == 3 || this.b == 4; } } );
//同上效果
> db.mycollection.find( function() { return this.a == 3 || this.b == 4; } );

$type 將會(huì)根據(jù)字段的 BSON 類型來檢索數(shù)據(jù)
復(fù)制代碼 代碼如下:

//返回 a 是字符串的記錄
> db.things.find( { a : { $type : 2 } } );
 
//返回 a 是 int 類型的記錄
> db.things.find( { a : { $type : 16 } } );

類型名稱映射

● Double : 1
● String : 2
● Object : 3
● Array : 4
● Binary data : 5
● Object id :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


Mongodb同樣支持正則表達(dá)式進(jìn)行檢索

復(fù)制代碼 代碼如下:

//檢索name屬性是以 u 開頭,4 結(jié)尾的所有用戶
> db.user.find( { name : /u.*4$/i } ).limit(2);
{ "_id" : 4, "name" : "user4", "userid" : 4, "age" : 20 }
{ "_id" : 14, "name" : "user14", "userid" : 14, "age" : 20 }
 
//同樣效果的查詢語句
> db.user.find( { name : { $regex : 'u.*4$', $options : 'i' } } ).limit(2);
{ "_id" : 4, "name" : "user4", "userid" : 4, "age" : 20 }
{ "_id" : 14, "name" : "user14", "userid" : 14, "age" : 20 }
 
//配合其他操作一起使用
> db.user.find( { name : { $regex : 'u.*4$', $options : 'i', $nin : [ 'user4' ] } } ).limit(2);
{ "_id" : 14, "name" : "user14", "userid" : 14, "age" : 20 }
 

排序
 
按照 last_name 屬性進(jìn)行升序排序返回所有文檔

復(fù)制代碼 代碼如下:

//1表示升序,-1表示降序
db.users.find( {} ).sort( { last_name : 1 } );

Group
復(fù)制代碼 代碼如下:
//語法:
db.coll.group( {
       cond     : {filed:conditions},
       key      : {filed: true},
       initial  : {count: 0, total_time:0},
       reduce   : function(doc, out){ },
       finalize : function(out){}
} );
 
參數(shù)說明:
   Key         :對(duì)那個(gè)字段進(jìn)行
   Group Cond  :查詢條件
   Initial     :初始化group計(jì)數(shù)器
   Reduce      :通常做統(tǒng)計(jì)操作
   Finalize    :通常都統(tǒng)計(jì)結(jié)果進(jìn)行進(jìn)一步操作,例如求平均值 Keyf:用一個(gè)函數(shù)來返回一個(gè)替代 KEY 的值
   
//例子
> db.test.group( {
       cond     : { "invoked_at.d" : { $gte : "2009-11", $lt : "2009-12" } },
       key      : {http_action: true},
       initial  : {count: 0, total_time:0},
       reduce   : function( doc, out ){ out.count++; out.total_time += doc.response_time },
       finalize : function(out){ out.avg_time = out.total_time / out.count } } );
   
[
  {
    "http_action" : "GET /display/DOCS/Aggregation",
    "count"       : 1,
    "total_time"  : 0.05,
    "avg_time"    : 0.05
  }
]
 


去重 類似于關(guān)系數(shù)據(jù)庫中的 Distinct

復(fù)制代碼 代碼如下:
> db.addresses.insert( { "zip-code" : 10010 } )
> db.addresses.insert( { "zip-code" : 10010 } )
> db.addresses.insert( { "zip-code" : 99701 } )
>
> db.addresses.distinct("zip-code");
[ 10010, 99701 ]
>
> //command 模式:
> db.runCommand( { distinct: 'addresses', key: 'zip-code' } )
{ "values" : [ 10010, 99701 ] }
>
> db.comments.save( { "user" : { "points" : 25 } } )
> db.comments.save( { "user" : { "points" : 31 } } )
> db.comments.save( { "user" : { "points" : 25 } } )
> db.comments.distinct("user.points");
[ 25, 31 ]

Mongodb 支持 skip 和 limit 命令來進(jìn)行分頁查詢

復(fù)制代碼 代碼如下:
//跳過前10條記錄
> db.user.find().skip(10);
//每頁返回8條記錄
> db.user.find().limit(8);
//跳過前20條記錄,并且每頁返回10條記錄
> db.user.find().skip(20).limit(8);
//下面這個(gè)語句跟上一條一樣,只是表達(dá)不夠清晰
> db.user.find({}, {}, 8, 20);

$elemMatch
復(fù)制代碼 代碼如下:
> t.find( { x : { $elemMatch : { a : 1, b : { $gt : 1 } } } } )
{ "_id" : ObjectId("4b5783300334000000000aa9"), "x" : [ { "a" : 1, "b" : 3 }, 7, { "b" : 99 }, { "a" : 11 } ] }
 
//同樣效果
> t.find( { "x.a" : 1, "x.b" : { $gt : 1 } } )

count()方法返回查詢記錄的總數(shù)
復(fù)制代碼 代碼如下:

db.orders.count( { ord_dt : { $gt : new Date('01/01/2012') } } )
//同樣效果
db.orders.find( { ord_dt : { $gt : new Date('01/01/2012') } } ).count()
 
//當(dāng)查詢語句用到了 skip() 和 limit() 方法的時(shí)候,
//默認(rèn)情況下 count() 會(huì)忽略這些方法,如果想要計(jì)算這些方法,
//需要給 count() 方法傳一個(gè) true 作為參數(shù)
> db.user.find( { _id : { $lt : 20 } } ).skip(3).limit(9).count();
20
> db.user.find( { _id : { $lt : 20 } } ).skip(3).limit(9).count(true);
9
>

$slice
復(fù)制代碼 代碼如下:

db.posts.find({}, {comments:{$slice: 5}}) // 前5條評(píng)論
db.posts.find({}, {comments:{$slice: -5}}) //后5條評(píng)論
db.posts.find({}, {comments:{$slice: [20, 10]}}) // 跳過20條, limit 10
db.posts.find({}, {comments:{$slice: [-20, 10]}}) // 后20條, limit 10
 

刪除 Delete
 
Remove 操作用于從集合中刪除記錄
復(fù)制代碼 代碼如下:

//刪除一條記錄
> db.stu.remove( { _id : 17 } );
 
//刪除所有記錄
> db.stu.remove( {} );
 
//某些情況下,當(dāng)你在對(duì)一個(gè)記錄執(zhí)行 remove 操作的時(shí)候,
//可能會(huì)有 update 操作在這個(gè)記錄上,這樣就可能刪除不掉這個(gè)記錄,
//如果你覺得這不盡人意,那么你可以在 remove 操作的時(shí)候加上 $atomic:
db.stu.remove( { rating : { $lt : 3.0 }, $atomic : true } );

更新 Update
復(fù)制代碼 代碼如下:

db.collection.update( criteria, objNew, upsert, multi )

參數(shù)說明:
    Criteria :用于設(shè)置查詢條件的對(duì)象
    Objnew   :用于設(shè)置更新內(nèi)容的對(duì)象
    Upsert   :如果記錄已經(jīng)存在,更新它,否則新增一個(gè)記錄
    Multi    :如果有多個(gè)符合條件的記錄,全部更新 注意:默認(rèn)情況下,只會(huì)更新第一個(gè)符合條件的記錄
 
save()
復(fù)制代碼 代碼如下:

//如果存在更新它,如果不存在,新增記錄
db.mycollection.save( { name : 'shawn' } );

$inc
復(fù)制代碼 代碼如下:

{ $inc : { field : value } } //把field的值加一個(gè)value
 
> db.user.findOne( { _id : 0 } );
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 22 }
> db.user.update( { _id : 0 }, { $inc : { age : 1 } } );
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 23 }

$set
復(fù)制代碼 代碼如下:

{ $set : { field : value } } 
// 把field的值設(shè)置成value,當(dāng)field不存在時(shí),增加一個(gè)字段,
// 類似SQL的set操作,value支持所有類型
 
// 把上面的 age 改回到 20
> db.user.update( { _id : 0 }, { $set : { age : 20 } } );
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 20 }
 
// 當(dāng) field 不存在時(shí),增加一個(gè)字段
> db.user.update( { _id : 0 }, { $set : { sex : 'boy' } } );
{ "_id" : 0, "sex" : "boy", "name" : "user0", "userid" : 0, "age" : 20 }

$unset
復(fù)制代碼 代碼如下:

{ $unset : { field : 1} } // 刪除給定的字段field
 
//刪除上一步增加的sex字段
> db.user.update( { _id : 0 }, { $unset : { sex : 1 } } );
{ "_id" : 0, "name" : "user0", "userid" : 0, "age" : 20 }

$push
復(fù)制代碼 代碼如下:

{ $push : { field : value } }
// 如果 filed 是一個(gè)已經(jīng)存在的數(shù)組,那么把 value 追加給 field
// 如果 field 原來不存在,那么新增 field 字段,把value的值賦給field
// 如果 field 存在,但是不是一個(gè)數(shù)組,將會(huì)出錯(cuò)
 
> db.sport.update( { _id : 0 }, { $push : { aihao : 'football' } } );

$pushAll
復(fù)制代碼 代碼如下:

{ $pushAll : { field : value_array } }
// 功能同$push,只是這里的 value 是數(shù)組,相當(dāng)于對(duì)數(shù)組里的每一個(gè)值進(jìn)行 $push 操作

$addToSet
復(fù)制代碼 代碼如下:

{ $addToSet : { field : value } }
// 如果 filed 是一個(gè)已經(jīng)存在的數(shù)組,并且 value 不在其中,那么把 value 加入到數(shù)組
// 如果 filed 不存在,那么把 value 當(dāng)成一個(gè)數(shù)組形式賦給 field
// 如果 field 是一個(gè)已經(jīng)存在的非數(shù)組類型,那么將會(huì)報(bào)錯(cuò)

$pop
復(fù)制代碼 代碼如下:

{ $pop : { field : 1 } }   //刪除數(shù)組中最后一個(gè)元素
 
{ $pop : { field : -1 } }  //刪除數(shù)組中第一個(gè)元素

$pull
復(fù)制代碼 代碼如下:

{ $pull : { field : _value } }
// 如果 field 是一個(gè)數(shù)組,那么刪除符合 _value 檢索條件的記錄
// 如果 field 是一個(gè)已經(jīng)存在的非數(shù)組,那么會(huì)報(bào)錯(cuò)

$pullAll
復(fù)制代碼 代碼如下:

{ $pullAll : { field : value_array } } //同$push類似,只是value的數(shù)據(jù)類型是一個(gè)數(shù)組

$rename
復(fù)制代碼 代碼如下:

{ $rename : { old_field_name : new_field_name } 
// 重命名指定的字段名稱,從1.7.2版本后開始支持
 
> db.user.update( { _id : 0 } , { $rename : { 'quantity' : 'qty'}});

特殊操作符:$

$ 操作符代表查詢記錄中第一個(gè)匹配條件的記錄項(xiàng)
 

復(fù)制代碼 代碼如下:

//例1
> db.t.find()
{
  "_id"      : ObjectId("4b97e62bf1d8c7152c9ccb74"),
  "title"    : "ABC",
  "comments" : [
                 { "by" : "joe", "votes" : 3 },
                 { "by" : "jane", "votes" : 7 }
               ]
}
> db.t.update( { 'comments.by' : 'joe' }, { $inc : { 'comments.$.votes' : 1 } }, false, true )
> db.t.find()
{
  "_id"      : ObjectId("4b97e62bf1d8c7152c9ccb74"),
  "title"    : "ABC",
  "comments" : [
                 { "by" : "joe", "votes" : 4 },
                 { "by" : "jane", "votes" : 7 }
               ]
}
 
//例2
> db.t.find();
{
  "_id" : ObjectId("4b9e4a1fc583fa1c76198319"),
  "x"   : [ 1, 2, 3, 2 ]
}
> db.t.update( { x : 2 }, { $inc : { "x.$": 1 } }, false, true);
> db.t.find();
{
  "_id" : ObjectId("4b9e4a1fc583fa1c76198319"),
  "x"   : [ 1, 3, 3, 2 ]
}
 
//在數(shù)組中用 $ 配合 $unset操作 符的時(shí)候,效果不是刪除匹配的元素,而是把匹配的元素變成了null,如:
> db.t.insert( { x: [ 1, 2, 3, 4, 3, 2, 3, 4 ] } )
> db.t.find()
{
  "_id" : ObjectId("4bde2ad3755d00000000710e"),
  "x"   : [ 1, 2, 3, 4, 3, 2, 3, 4 ]
}
> db.t.update( { x : 3 }, { $unset : { "x.$" : 1 } } )
> t.find()
{
  "_id" : ObjectId("4bde2ad3755d00000000710e"),
  "x"   : [ 1, 2, null, 4, 3, 2, 3, 4 ]
}

 
圖形化管理工具
 
MongoDB有幾款圖形化的管理工具,參考:
http://docs.mongodb.org/ecosystem/tools/administration-interfaces/
 

您可能感興趣的文章:
  • mongodb中非常好用的Aggregate入門教程
  • MongoDB入門教程之C#驅(qū)動(dòng)操作實(shí)例
  • MongoDB入門教程之常用的運(yùn)維技術(shù)介紹
  • MongoDB入門教程之分片技術(shù)詳解
  • MongoDB入門教程之主從復(fù)制配置詳解
  • MongoDB入門教程之索引操作淺析
  • MongoDB入門教程之聚合和游標(biāo)操作介紹
  • MongoDB入門教程之細(xì)說MongoDB數(shù)據(jù)庫的增刪查改操作
  • MongoDB入門教程之Windows下的MongoDB數(shù)據(jù)庫安裝圖解
  • MongoDB 簡單入門教程(安裝、基本概念、創(chuàng)建用戶)

標(biāo)簽:邯鄲 丹東 昭通 本溪 景德鎮(zhèn) 大理 吉安 鶴崗

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)》,本文關(guān)鍵詞  MongoDB,入門教程,包含,安裝,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)》相關(guān)的同類信息!
  • 本頁收集關(guān)于MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    手机看片日韩av| 日韩精品中文字幕在线不卡尤物| 黄色毛片av| 欧美性老头oldtight| 特黄特色免费视频| 蜜桃极品自拍av| 亚洲一区二区中文在线| 四虎8848精品成人免费网站| 成人免费视频视频在线观看免费| 欧美少妇bbw| 大波视频国产精品久久| 在线视频观看亚洲| jizz国产在线| 精品日本一区二区三区在线观看| 日韩欧美高清| 中文字幕一区二区三中文字幕| 久操免费在线视频| 夜夜爽久久精品91| 麻豆专区一区二区三区四区五区| 色呦呦视频在线观看| 欧美在线视频在线播放完整版免费观看| 亚洲av中文无码乱人伦在线视色| 中国jizz妇女jizz妇女| 天堂va蜜桃一区二区三区漫画版| 精品av一区二区| 欧美成人精品高清在线播放| 一级黄在线观看| 一本久久精品| 亚洲精品久久区二区三区蜜桃臀| 成人黄色电影网址| 亚洲第一影院| 欧美成人激情视频免费观看| 免费人成视频在线播放| 欧美男人操女人视频| 国产视频一区在线观看一区免费| 性感美女久久精品| 中文一区在线播放| 午夜影院免费播放| 国产裸体歌舞团一区二区| 99视频在线观看地址| 久久人人爽人人爽人人片av高请| www.一区二区三区.com| 国产精品免费视频一区二区三区| 四虎海外永久免费网址| 午夜精品久久久久久久第一页按摩| 三上悠亚在线观看视频| 亚洲综合中文字幕68页| 国产欧美一区二区三区网站| 亚洲欧美综合| 日本精品一区二区三区四区的功能| 99热超碰在线| 中文字幕在线不卡| 高清国产mv在线观看| 这里只有精品久久| 亚洲国产中文字幕在线观看| 91精品国自产| 精品国产1区二区| 久久国产精品无码网站| 欧美1区2区3区| 久久久久久国产精品免费播放| 黄色动漫免费网站| 老鸭窝亚洲一区二区三区| 亚洲欧美成人综合| 欧美亚洲一级| 97色伦图片97色伦在线电影| 亚洲qvod图片区电影| 91久久精品一区二区别| 欧美精品日日操| 97人洗澡人人免费公开视频碰碰碰| 中文字幕九色91在线| 亚洲v在线观看| 椎名由奈jux491在线播放| 欧美日韩经典丝袜| 久久三级中文| 影音先锋男人每日资源站| 69ww免费视频播放器| 午夜欧美视频| 永久免费av网站| 26uuu成人网一区二区三区| 91精品国产高清一区二区三蜜臀| 天天色棕合合合合合合合| 国产丝袜在线观看视频| 欧美激情一区| 国产精品高潮呻吟久久久久| 手机免费看av| 国产自摸综合网| 欧美激情国产精品免费| 国产在线播放一区二区| 国产福利电影在线| 成人区一区二区| 免费欧美日韩| 国产网站在线播放| 福利视频在线| 亚洲高清国产拍精品26u| 一区二区成人国产精品| 神马久久影视大全| 亚洲美女免费视频| 老司机2019福利精品视频导航| 欧美一三区三区四区免费在线看| 日韩欧美在线电影| 91性高潮久久久久久久| 最近高清中文在线字幕在线观看| 久久久久一区二区三区四区| 在线视频不卡一区二区| 五月婷婷亚洲| 永久免费看mv网站入口| 国产一区二区视频在线看| 中文字幕欧美日韩在线| 亚洲乱码国产乱码精品精| 日韩精品免费看| 欧美成人精品1314www| 在线成人免费观看| 夫妇露脸对白88av| 中文字幕66页| 青青草原综合久久大伊人精品| 蜜桃久久精品一区二区| 黄色小说在线播放| 黄网站色视频免费观看| 日本午夜在线观看| 91pron在线| 91精品国产91久久久久久最新| 中文字幕成人动漫| 五月天婷婷基地| 三级全黄的视频在线观看| 91偷拍与自偷拍精品| 国产日韩欧美三级| 亚洲一区免费网站| 欧美激情视频在线观看| 成人一区福利| 伊人网中文字幕| 美女一区视频| www.亚洲一区二区| 欧美精品总汇| 午夜精品久久久久久久99老熟妇| 亚洲电影中文字幕| 高清性色生活片在线观看| 亚洲偷熟乱区亚洲香蕉av| 日本韩国免费观看| 成人福利在线看| 久久综合久色欧美综合狠狠| 国产又大又粗又硬| 亚洲欧洲激情在线| 在线黄色免费观看| 偷窥自拍欧美色图| 欧美激情18p| 精品国产第一区二区三区观看体验| 欧美日韩精品一区| 在线观看国产福利| 色爱av美腿丝袜综合粉嫩av| 国内自拍在线观看| 欧美午夜片在线观看| 日韩三级电影网| 9色视频在线观看| 视频一区二区视频| 亚洲高清在线观看视频| 国产精品视频h| 99re91这里只有精品| 国产精品91在线| 日本韩国欧美一区| 综合视频在线观看| av直播在线观看| 亚洲一区影院| 裸体素人女欧美日韩| 刘亦菲久久免费一区二区| 国产精品yjizz视频网| 在线观看国产免费视频| 国产丝袜在线| 国产精品99久久久久久久久| 色在线免费观看| 亚洲二区三区不卡| 成人污视频在线观看| 国产一区二区在线免费视频| 久久精品66| 福利一区二区三区视频在线观看| 99热国内精品永久免费观看| 激情综合五月网| 国产免费一区二区三区四在线播放| 韩国欧美一区| 国产在线视频精品一区| 永久免费黄色软件| 国产黄色特级片| 自拍小视频在线观看| 91免费视频国产| 四虎影视亚洲| 国色天香久久精品国产一区| 丝袜美腿综合| 国产a√精品区二区三区四区| 免费亚色电影在线观看| 7m第一福利500精品视频| 松下纱荣子在线观看| 日本一区二区免费高清| 精品久久国产精品| 久久中文亚洲字幕| 松下纱荣子在线观看| 欧美顶级毛片在线播放| 日韩一区二区电影在线观看| 欧美伦理视频网站| 九色porny丨精品自拍视频| jjzz黄色片| 伊人中文在线| 亚洲七七久久综合桃花剧情介绍| 一本色道久久综合一区| 国产在线精品一区二区三区》| 色综合婷婷久久| 欧美精品三区| 99热这里只有精品66| 中日韩高清电影网| 九九**精品视频免费播放| 海角国产乱辈乱精品视频| 玉米视频成人免费看| 欧美性高清videossexo| 亚洲激情亚洲| 岳乳丰满一区二区三区| 国产人妻黑人一区二区三区| 一区二区在线不卡| 成人精品一区二区三区免费| 欧美韩国理论所午夜片917电影| 天天看天天摸天天操| 国产不卡高清在线观看视频| 欧美日韩国产成人| 91久久在线播放| 粉嫩aⅴ一区二区三区四区五区| 蜜桃视频在线观看播放| 国产主播在线播放| 欧美日韩久久久久久| 亚洲最大色图| 在线观看视频免费| 精品国产一区二区三区2021| 日韩第一页在线| 91免费小视频| 精品中国亚洲| 亚洲视频国产| 欧美精品三级| 99热99精品| 久久久久久久久综合| 91国内视频| 国产精品13p| 四虎永久在线精品免费网址| 妖精视频一区二区| 特级黄国产片一级视频播放| 少妇特黄一区二区三区| 成人免费看片'免费看| 国产一区二区久久| 性国裸体高清亚洲| 91免费在线视频网站| 国产福利热线视频| 蜜桃一区二区三区在线| 欧美日韩1区2区| 国产在线xxxx| 亚洲熟妇无码一区二区三区| 韩国av一区| 99久久国产宗和精品1上映| 国产福利精品在线| 久草视频精品在线| 人妻熟女aⅴ一区二区三区汇编| 91香蕉国产在线观看| av一区二区久久| 国产青草视频在线观看视频| 可以看美女隐私的网站| 韩国精品视频| 伊人国产在线视频| 亚洲国产一区二区三区青草影视| 久久久99久久精品欧美| av大全在线免费看| 欧美乱大交xxxxx另类电影| 国产香蕉精品| 女人18毛片水真多18精品| 国产经典久久久| 国产高潮国产高潮久久久91| 亚洲 欧美 日韩在线| 91麻豆精品91久久久久同性| 农村妇女一区二区| 超碰免费在线公开| 秋霞午夜一区二区| 亚洲午夜久久久久中文字幕| 国产午夜小视频| 国产三区在线视频| 色婷婷亚洲mv天堂mv在影片| 亚洲免费av一区二区| 亚洲欧美不卡| 久久99高清| 国产在线视频2019最新视频| shkd中文字幕久久在线观看| 久久天天做天天爱综合色| 精品视频在线观看免费| 人妻少妇被粗大爽9797pw| 天海翼精品一区二区三区| 国产精品美女一区二区视频| 国产成人一区在线| 亚洲精品乱码久久久久久久久久久久| 91欧美一区二区| 激情图片中文字幕| 亚洲日本在线观看视频| 亚洲天堂男人网| 国产一区国产精品| 成人免费午夜电影| 久久亚洲精品中文字幕冲田杏梨| 欧美狂猛xxxxx乱大交3| 最近中文字幕mv2018在线高清| 99久久人妻无码中文字幕系列| 少妇人妻偷人精品一区二区| 自拍av一区二区三区| 中文有码久久| 57pao成人永久免费视频| 日本aa大片在线播放免费看| 日韩夫妻性生活xx| 一卡二卡三卡在线观看| 99精品中文字幕| 一个人免费观看日本www视频| 美女被啪啪一区二区| 欧美精品久久久久久久久46p| 日韩经典一区二区三区| 成人午夜电影在线观看| 国产经典自拍视频在线观看| 亚洲五码中文字幕| 黄色成人在线观看网站| 欧美日韩视频免费看| 国内精品一区视频| 久久99精品久久久久久青青91| 中文字幕一区二区三区精彩视频| 粉嫩久久99精品久久久久久夜| 日韩国产高清视频在线| 婷婷五月精品中文字幕| rebdb初裸写真在线观看| 欧美性色黄大片手机版| 自拍偷在线精品自拍偷无码专区| 日本中文字幕视频一区| av网站大全在线观看|