自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

野心勃勃的NoSQL新貴 MongoDB應(yīng)用實(shí)戰(zhàn)

數(shù)據(jù)庫 其他數(shù)據(jù)庫 MongoDB
本文不是用長篇的文字來理論性描述MongoDB的各方面知識(shí),而是用圖文并茂的方法來討論MongoDB,希望用最短的時(shí)間使開發(fā)人員熟悉MongoDB。

MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫,由C++語言編寫,旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案。其名字來自humongous這個(gè)單詞的中間部分,從名字可見其野心所在就是海量數(shù)據(jù)的處理。本文是一個(gè)MongoDB的入門級(jí)教程,手把手的教會(huì)讀者使用MongoDB,并將學(xué)習(xí)過程中可能遇到的問題一一列舉。本文不是用長篇的文字來理論性描述MongoDB的各方面知識(shí),而是用圖文并茂的方法來討論MongoDB,希望用最短的時(shí)間使開發(fā)人員熟悉MongoDB。

一、MongoDB簡介

2011年將被記住,因?yàn)檫@一年SQL將死;這一年,關(guān)系數(shù)據(jù)庫從一線退下;這一年開發(fā)人員發(fā)現(xiàn)他們沒必要為了持久化數(shù)據(jù),而將每個(gè)對象轉(zhuǎn)化為表格結(jié)構(gòu)。

2011年是文檔數(shù)據(jù)庫的一年,盡管一直在穩(wěn)步發(fā)展勢頭,通過過去八年多的發(fā)展,現(xiàn)在有各種穩(wěn)定的文檔數(shù)據(jù)庫——從基于亞馬遜和谷歌的云,到各種開放源碼工具,尤其是MongoDB。

那么,MongoDB是什么?這里的五件事是每個(gè)開發(fā)人員應(yīng)該知道的:

  1. MongoDB是一個(gè)獨(dú)立的服務(wù)器;
  2. 它是基于文檔的,而不是基于表格的;
  3. 它是非結(jié)構(gòu)化的;
  4. 不必去學(xué)習(xí)另一種查詢語言;
  5. 它具有強(qiáng)大的主流開發(fā)語言支持,如 C#、C++、Java、PHP、Perl、Python、Ruby。

1、MongoDB 是一個(gè)獨(dú)立的服務(wù)器

如MySQL或PostgreSQL一樣,MongoDB提供偵聽端口以便接入。它提供了用于查詢,創(chuàng)建,更新和刪除的工具。從理論上講,你使用它的工作方式與你使用MySQL或PostgreSQL的工作方式相同:連接,執(zhí)行任務(wù),并關(guān)閉連接。

2、MongoDB是非結(jié)構(gòu)化的

MongoDB 沒有結(jié)構(gòu)化語言。如果你想創(chuàng)建一個(gè)新的文檔類型,你不用做任何事來告訴數(shù)據(jù)庫關(guān)于這些數(shù)據(jù)的結(jié)構(gòu),而僅僅是存到數(shù)據(jù)庫中即可。

簡單的說,MongoDB使用類似JavaScript或PHP的類型處理方式。也就是說,數(shù)據(jù)庫是靈活的弱類型。

雖然有一些數(shù)據(jù)是有限制條件的(大塊的數(shù)據(jù)可能需要一些明確的處理),但在大多數(shù)情況下,你可以像寫PHP代碼一樣編寫你的MongoDB代碼。

3、不必去學(xué)習(xí)另一種查詢語言

還記得這些你寫的數(shù)據(jù)庫抽象層嗎?還記得那些你處理過的ORM層嗎?現(xiàn)在,你可以將它們?nèi)縼G棄。在MongoDB中你不需要他們。MongoDB沒有很多查詢語句。在大多數(shù)情況下,只需給它一個(gè)數(shù)組指定你想要的信息,然后它會(huì)給你返回文檔的數(shù)組。如果你想運(yùn)行一些非常復(fù)雜的查詢(如Map-Reduce操作),可以向MongoDB傳遞JavaScript,其內(nèi)部的JavaScript引擎可以解析這個(gè)腳本。

4、MongoDB是神速的

開發(fā)時(shí)間也短,因?yàn)闆]有結(jié)構(gòu)需要管理和很少(如果有的話)的數(shù)據(jù)映射。

學(xué)習(xí)曲線很平滑,因?yàn)闆]有新的查詢語言學(xué)習(xí)。代碼是簡潔的。畢竟,無須任何其他ORM,封裝可以非常簡單。你的代碼是未來的保證。向你的對象增加更多的字段是很輕松的。因此,需求變化了,你可以很快修改代碼以便適應(yīng)。

MongoDB足以讓我意識(shí)到它有改變游戲規(guī)則的潛力。這也是讓大家主張使用新一代的文檔數(shù)據(jù)庫代替基于SQL的關(guān)系數(shù)據(jù)庫的原因。將關(guān)系數(shù)據(jù)庫留在塵土里,更可能的是讓它們做它們能做好的事情:存儲(chǔ)屬于行和表的數(shù)據(jù)。

#p#

二、MongoDB服務(wù)器安裝

MongoDB的官方下載站是http://www.mongodb.org/downloads,可以去上面下載最新的程序下來。在下載頁面可以看到,對操作系統(tǒng)支持很全面,OS X、Linux、Windows、Solaris都支持,而且都有各自的32位和64位版本。目前的穩(wěn)定版本是1.8.1版本。

注意:

1. MongoDB 1.8.1 Linux版要求glibc必須是2.5以上,所以需要先確認(rèn)操作系統(tǒng)的glibc的版本,筆者最初用Linux AS 4安裝不上,最后用的是RHEL5來安裝才成功的;

2. 在32位平臺(tái)MongoDB不允許數(shù)據(jù)庫文件(累計(jì)總和)超過2G,而64位平臺(tái)沒有這個(gè)限制。本文都是采用32位系統(tǒng)。

#p#

Windows版本服務(wù)器安裝

(1)、下載MongoDB

url地址: http://downloads.mongodb.org/win32/mongodb-win32-i386-1.8.1.zip

(2)、設(shè)置MongoDB目錄

將其解壓到 d:\,再重命名為mongodb,路徑為d:\mongodb

(3)、設(shè)置數(shù)據(jù)文件路徑

在d:盤建一個(gè)db文件夾,路徑d:\db

(4)、啟動(dòng)MongoDB服務(wù)

進(jìn)入 cmd 提示符控制臺(tái),D:\mongodb\bin\mongod.exe --dbpath=d:\data\db

  1. D:\mongodb\bin>D:\mongodb\bin\mongod --dbpath=d:\data\db  
  2. Sun Apr 10 22:34:09 [initandlisten] MongoDB starting : pid=5192 port=27017 dbpat  
  3. h=d:\data\db 32-bit  
  4. ** NOTE: when using MongoDB 32 bit, you are limited to about 2 gigabytes of data  
  5. **       see http://blog.mongodb.org/post/137788967/32-bit-limitations  
  6. **       with --dur, the limit is lower  
  7. Sun Apr 10 22:34:09 [initandlisten] db version v1.8.1, pdfile version 4.5  
  8. Sun Apr 10 22:34:09 [initandlisten] git version: a429cd4f535b2499cc4130b06ff7c26  
  9. f41c00f04  
  10. Sun Apr 10 22:34:09 [initandlisten] build sys info: windows (5, 1, 2600, 2, 'Ser  
  11. vice Pack 3') BOOST_LIB_VERSION=1_35 
  12. Sun Apr 10 22:34:09 [initandlisten] waiting for connections on port 27017  
  13. Sun Apr 10 22:34:09 [websvr] web admin interface listening on port 28017 

MongoDB服務(wù)端的默認(rèn)連接端口是 27017

(5)、將MongoDB作為 Windows 服務(wù)隨機(jī)啟動(dòng)

先創(chuàng)建D:\mongodb\logs\mongodb.log文件,用于存儲(chǔ)MongoDB的日志文件, 再安裝系統(tǒng)服務(wù):

  1. D:\mongodb\bin\mongod --dbpath=d:\data\db --logpath=d:\mongodb\logs\mongodb.log --install  
  2. D:\mongodb\bin>D:\mongodb\bin\mongod --dbpath=d:\data\db --logpath=d:\mongodb\lo  
  3. gs\mongodb.log --install  
  4. all output going to: d:\mongodb\logs\mongodb.log  
  5. Creating service MongoDB.  
  6. Service creation successful.  
  7. Service can be started from the command line via 'net start "MongoDB"'.  
  8. D:\mongodb\bin>net start mongodb  
  9. Mongo DB 服務(wù)已經(jīng)啟動(dòng)成功。  
  10. D:\mongodb\bin> 

(6)、客戶端連接驗(yàn)證

新打開一個(gè)CMD輸入:d:\mongodb\bin\mongo,如果出現(xiàn)下面提示,那么您就可以開始MongoDB之旅了:

  1. D:\mongodb\bin>d:\mongodb\bin\mongo  
  2. MongoDB shell version: 1.8.1  
  3. connecting to: test  
  4. > 

(7)、查看MongoDB日志

查看D:\mongodb\logs\mongodb.log文件,即可對MongoDB的運(yùn)行情況進(jìn)行查看或排錯(cuò)了:

 

這樣就完成了Windows平臺(tái)的MongoDB安裝。

#p#

Linux版服務(wù)器安裝

(1)、下載MongoDB

curl -O http://fastdl.mongodb.org/linux/mongodb-linux-i686-1.8.1.tgz

(2)、設(shè)置MongoDB目錄

將其解壓到/Apps,再重命名為mongodb,路徑為/Apps/mongodb

(3)、設(shè)置數(shù)據(jù)文件路徑

建立/data/db的目錄, mkdir –p /data/db

(4)、啟動(dòng)MongoDB服務(wù)

  1. /Apps/mongodb/bin/mongod --dbpath=/data/db  
  2.  
  3. [root@localhost ~]# /Apps/mongodb/bin/mongod --dbpath=/data/db  
  4. Sun Apr  8 22:41:06 [initandlisten] MongoDB starting : pid=13701 port=27017 dbpath=/data/db 32-bit   
  5. ** NOTE: when using MongoDB 32 bit, you are limited to about 2 gigabytes of data  
  6. **       see http://blog.mongodb.org/post/137788967/32-bit-limitations  
  7. **       with --dur, the limit is lower  
  8. Sun Apr  8 22:41:06 [initandlisten] db version v1.8.1, pdfile version 4.5  
  9. Sun Apr  8 22:41:06 [initandlisten] git version: a429cd4f535b2499cc4130b06ff7c26f41c00f04  
  10. Sun Apr  8 22:41:06 [initandlisten] build sys info: Linux bs-linux32.10gen.cc 2.6.21.7-2.fc8xen #1 SMP Fri Feb 15 12:39:36 EST 2008 i686 BOOST_LIB_VERSION=1_37 
  11. Sun Apr  8 22:41:06 [initandlisten] waiting for connections on port 27017  
  12. Sun Apr  8 22:41:06 [websvr] web admin interface listening on port 28017 

MongoDB 服務(wù)端的默認(rèn)連接端口是 27017

(5)、將MongoDB作為 Linux 服務(wù)隨機(jī)啟動(dòng)

先創(chuàng)建/Apps/mongodb/logs/mongodb.log文件,用于存儲(chǔ)MongoDB的日志文件

vi /etc/rc.local, 使用vi編輯器打開配置文件,并在其中加入下面一行代碼

  1. /Apps/mongodb/bin/mongod --dbpath=/data/db --logpath=/Apps/mongodb/logs/mongodb.log 

(6)、客戶端連接驗(yàn)證

新打開一個(gè)Session輸入:/Apps/mongodb/bin/mongo,如果出現(xiàn)下面提示,那么您就可以開始mongo之旅了

  1. [root@localhost ~]# /Apps/mongodb/bin/mongo  
  2. MongoDB shell version: 1.8.1  
  3. connecting to: test  
  4. > 

(7)、查看MongoDB日志

查看/Apps/mongodb/logs/mongodb.log文件,即可對MongoDB的運(yùn)行情況進(jìn)行查看或排錯(cuò)了

  1. [root@localhost logs]# pwd  
  2. /Apps/mongodb/logs  
  3. [root@localhost logs]# ll  
  4. 總計(jì) 0  
  5. -rw-r--r-- 1 root root 0 04-08 20:15 mongodb.log  
  6. [root@localhost logs]# 

這樣就完成了Linux平臺(tái)的MongoDB安裝。

#p#

三、MongoDB客戶端訪問 – Shell方式

MongoDB是MongoDB自帶的交互式Javascript shell,用來對MongoDB進(jìn)行操作和管理的交互式環(huán)境。

使用 "./mongo --help" 可查看相關(guān)連接參數(shù),下面將從常見的操作,如插入,查詢,修改,刪除等幾個(gè)方面闡述MongoDB shell的用法

1、插入記錄

  1. > use my_mongodb  
  2. switched to db my_mongodb  
  3. > db.user.insert({uid:1,username:"Tom",age:25});  
  4. > db.user.insert({uid:2,username:"Jerry",age:25});  
  5. > 

本例向數(shù)據(jù)庫my_mongodb的表user中插入了2條記錄。MongoDB會(huì)隱式的創(chuàng)建數(shù)據(jù)庫my_mongodb和表user,所以這個(gè)例子沒有建庫和建表的過程,可以通過show dbs和show collections來查看數(shù)據(jù)庫及表,具體如下:

  1. > show dbs  
  2. admin   (empty)  
  3. local   (empty)  
  4. my_mongodb      0.0625GB    ---隱式創(chuàng)建的數(shù)據(jù)庫  
  5. > show collections  
  6. system.indexes  
  7. user                         ---隱式創(chuàng)建的表  
  8. > 

2、查詢記錄

查詢表中的全部記錄:

  1. >  db.user.find();  
  2. { "_id" : ObjectId("4f81a49b779282ca68fd8a59"), "uid" : 1, "username" : "Tom", "age" : 25 }  
  3. { "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 25 }  
  4. > 

查詢用戶名是 ”Jerry” 記錄:

  1. > db.user.find({username:"Jerry"});  
  2. { "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 25 }  
  3. > 

3、修改記錄

將用戶ID是2的記錄的年齡修改為100:

  1. > db.user.update({uid:2},{$set:{age:100}}) ;  
  2. > 

查詢一下是否改過來了:

  1. >  db.user.find({uid:2});  
  2. { "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 100 }  
  3. > 

4、刪除記錄

將用戶ID是1的記錄從表user中刪除:

  1. > db.user.remove({uid:1});  
  2. > db.user.find();   
  3. { "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 100 }  
  4. > 

經(jīng)驗(yàn)證,該記錄確實(shí)被刪除了。

MongoDB Shell的用法豐富且簡單易懂,大家有興趣可以到官網(wǎng)上去詳細(xì)了解一下。

#p#

四、MongoDB客戶端訪問 – C#

接下來我們要開始最簡單的MongoDB連接,訪問數(shù)據(jù)之旅了。MongoDB提供各種主流與非主流語言的開發(fā)驅(qū)動(dòng),以便適應(yīng)各個(gè)方向的開發(fā)人員。

1、下載驅(qū)動(dòng)

C#驅(qū)動(dòng)的下載地址為:

https://github.com/downloads/mongodb/mongo-csharp-driver/CSharpDriver-1.0.0.4098.zip

將其解壓到D:\mongodb\drivers\目錄下,其中有2個(gè)重要的dll文件

MongoDB.Bson.dll --序列化、Json相關(guān)

MongoDB.Driver.dll --驅(qū)動(dòng)

2、添加引用

新建一個(gè)C#的項(xiàng)目,添加引用,將上面兩個(gè)dll文件引入到項(xiàng)目里面:

 

3、代碼解析

下面以一個(gè)插入的操作為例,來一步一步解釋代碼:

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. //添加命名空間  
  6. using MongoDB.Bson;  
  7. using MongoDB.Driver;  
  8. namespace ConsoleApplication3  
  9. {  
  10.     class Program  
  11.     {  
  12.         static void Main(string[] args)  
  13.         {  
  14.             //MongoDB服務(wù)器連接串  
  15.             string connectionString = "mongodb://192.168.1.103";  
  16.             MongoServer server = MongoServer.Create(connectionString);  
  17.             //連接到 mongodb_c_demo 數(shù)據(jù)庫  
  18.             MongoDatabase db = server.GetDatabase("mongodb_c_demo");  
  19.             //獲取集合 fruit  
  20.             MongoCollection collection = db.GetCollection("fruit");  
  21.             //創(chuàng)建對象 fruit_1  
  22.             BsonDocument fruit_1 = new BsonDocument  
  23.             {  
  24.               { "name""apple" },  
  25.               { "color""red" }  
  26.             };  
  27.             //創(chuàng)建對象 fruit_2  
  28.             BsonDocument fruit_2 = new BsonDocument  
  29.             {  
  30.               { "name""banana" },  
  31.               { "color""yellow" }  
  32.             };  
  33.             //將對象 fruit_1 放到集合 fruit 中  
  34.             collection.Insert(fruit_1);  
  35.             //將對象 fruit_2 放到集合 fruit 中  
  36.             collection.Insert(fruit_2);  
  37.             //以上代碼完成的就是向fruit表中插入2條數(shù)據(jù),用mysql的語法解釋即  
  38.             //insert into mongodb_c_demo.fruit (name, color)   
  39.             //values ('apple', 'red'), ('banana', 'yellow');  
  40.         }  
  41.     }  

4、通過MongoDB Shell來驗(yàn)證是否插入:

  1. > use mongodb_c_demo  
  2. switched to db mongodb_c_demo  
  3. > db.fruit.find();   
  4. "_id" : ObjectId("4da1c5fdfad96211a08f5752"), "name" : "apple""color" : "red" }  
  5. "_id" : ObjectId("4da1c5fdfad96211a08f5753"), "name" : "banana""color" : "yellow" }  
  6. >  

【編輯推薦】

  1. 走進(jìn)MongoDB的世界 展開MongoDB的學(xué)習(xí)之旅
  2. MongoDB學(xué)習(xí)筆記(一) MongoDB介紹及安裝
  3. MongoDB學(xué)習(xí)筆記(二) 通過samus驅(qū)動(dòng)實(shí)現(xiàn)基本數(shù)據(jù)操作
  4. MongoDB學(xué)習(xí)筆記(三) 在MVC模式下通過Jqgrid表格操作MongoDB數(shù)據(jù)
  5. MongoDB學(xué)習(xí)筆記(四) 用MongoDB的文檔結(jié)構(gòu)描述數(shù)據(jù)關(guān)系
責(zé)任編輯:艾婧 來源: IT168
相關(guān)推薦

2023-05-25 20:16:06

2020-01-03 10:46:16

Windows 功能系統(tǒng)

2021-10-20 16:00:05

Windows 11操作系統(tǒng)微軟

2017-06-20 10:58:31

云助力

2024-04-26 11:40:23

AI硬件Rabbit

2018-03-28 09:30:54

數(shù)字化轉(zhuǎn)型

2012-08-10 10:18:44

DeltacloudApache開源云服務(wù)器

2013-04-02 15:32:28

2022-10-27 21:34:28

數(shù)據(jù)庫機(jī)器學(xué)習(xí)架構(gòu)

2011-12-09 13:31:21

ARM服務(wù)器英特爾

2012-04-05 14:32:21

MongoDB

2017-12-21 06:16:07

2018-08-29 15:23:18

數(shù)據(jù)庫NoSQLMongoDB

2015-08-04 09:50:10

2012-05-09 17:28:03

騰訊XTools云計(jì)算

2015-07-20 16:47:22

MongoDB

2011-04-01 09:29:52

MySQLMongoDB

2010-07-12 11:41:55

2014-07-31 09:13:54

R語言MongoDB

2010-09-07 09:07:33

MongoDBCouchDB
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)