MongoDB學(xué)習(xí)筆記(五) MongoDB文件存取操作
由于MongoDB的文檔結(jié)構(gòu)為BJSON格式(BJSON全稱:Binary JSON),而B(niǎo)JSON格式本身就支持保存二進(jìn)制格式的數(shù)據(jù),因此可以把文件的二進(jìn)制格式的數(shù)據(jù)直接保存到MongoDB的文檔結(jié)構(gòu)中。但是由于一個(gè)BJSON的最大長(zhǎng)度不能超過(guò)4M,所以限制了單個(gè)文檔中能存入的最大文件不能超過(guò)4M。為了提供對(duì)大容量文件存取的支持,samus驅(qū)動(dòng)提供了“GridFS”方式來(lái)支持,“GridFS”方式文件操作需要引入新的程序集“MongoDB.GridFS.dll”。下面我們分別用兩種方式來(lái)實(shí)現(xiàn)。
一、在文檔對(duì)象中存取文件
當(dāng)文件大小較小的時(shí)候,直接存入文檔對(duì)象實(shí)現(xiàn)起來(lái)更簡(jiǎn)潔。比如大量圖片文件的存取等,一般圖片文件都不會(huì)超過(guò)4M。我們先實(shí)現(xiàn)一個(gè)上傳圖片存入數(shù)據(jù)庫(kù),再取出來(lái)寫(xiě)回頁(yè)面的例子:
1. 把圖片存到BJSON中
/// <summary>
/// 把圖片存到BJSON中
/// </summary>
public void SaveImgBJSON(byte[] byteImg)
{
Document doc = new Document();
doc["ID"] = 1;
doc["Img"] = byteImg;
mongoCollection.Save(doc);
}
2. 獲取BJSON方式存儲(chǔ)的圖片字節(jié)數(shù)據(jù)
/// <summary>
/// 獲取BJSON方式存儲(chǔ)的圖片字節(jié)數(shù)據(jù)
/// </summary>
public byte[] GetImgBJSON()
{
Document doc= mongoCollection.FindOne(new Document { { "ID", 1 } });
return doc["Img"] as Binary;
}
上面兩段代碼是在對(duì)MongoDB相關(guān)操作進(jìn)行BLL封裝類中添加的兩個(gè)方法,封裝方式查看上節(jié)內(nèi)容。下面看看在webform中如何調(diào)用:
在界面拖出一個(gè)FileUpload控件和一個(gè)Button控件,頁(yè)面cs類加如下方法:
protected void Button1_Click(object sender, EventArgs e)
{
ImgBLL imgBll = new ImgBLL();
imgBll.DeleteAll();
imgBll.SaveImgBJSON(FileUpload1.FileBytes);
Response.BinaryWrite(imgBll.GetImgBJSON());
}
二、用GridFS方式存取文件
在實(shí)現(xiàn)GridFS方式前我先講講它的原理,為什么可以存大文件。驅(qū)動(dòng)首先會(huì)在當(dāng)前數(shù)據(jù)庫(kù)創(chuàng)建兩個(gè)集合:"fs.files"和"fs.chunks"集合,前者記錄了文件名,文件創(chuàng)建時(shí)間,文件類型等基本信息;后者分塊存儲(chǔ)了文件的二進(jìn)制數(shù)據(jù)(并支持加密這些二進(jìn)制數(shù)據(jù))。分塊的意思是把文件按照指定大小分割,然后存入多個(gè)文檔中。"fs.files"怎么知道它對(duì)應(yīng)的文件二進(jìn)制數(shù)據(jù)在哪些塊呢?那是因?yàn)樵?fs.chunks"中有個(gè)"files_id"鍵,它對(duì)應(yīng)"fs.files"的"_id"。"fs.chunks"還有一個(gè)鍵(int型)"n",它表明這些塊的先后順序。這兩個(gè)集合名中的"fs"也是可以通過(guò)參數(shù)自定義的。
如果你只是想知道怎么用,可以忽略上面這段話,下面將用法:
1. GridFS方式的文件新建,讀取,刪除
private string GridFsSave(byte[] byteFile)
{
string filename = Guid.NewGuid().ToString();
//這里GridFile構(gòu)造函數(shù)有個(gè)重載,bucket參數(shù)就是用來(lái)替換那個(gè)創(chuàng)建集合名中默認(rèn)的"fs"的。
GridFile gridFile = new GridFile(mongoDatabase);
using (GridFileStream gridFileStream = gridFile.Create(filename))
{
gridFileStream.Write(byteFile, 0, byteFile.Length);
}
return filename;
}
private byte[] GridFsRead(string filename)
{
GridFile gridFile = new GridFile(mongoDatabase);
GridFileStream gridFileStream = gridFile.OpenRead(filename);
byte[] bytes = new byte[gridFileStream.Length];
gridFileStream.Read(bytes, 0, bytes.Length);
return bytes;
}
private void GridFsDelete(string filename)
{
GridFile gridFile = new GridFile(mongoDatabase);
gridFile.Delete(new Document("filename", filename));
}
2. 再次封裝GridFS操作,新文檔只存儲(chǔ)文件名稱,相當(dāng)于只是一個(gè)鍵,新文檔還可以有除“文件名”之外其他的鍵。
/// <summary>
/// 把圖片存到GridFS中
/// </summary>
public void SaveImgGridFS(byte[] byteImg)
{
string filename = GridFsSave(byteImg);
Document doc = new Document();
doc["ID"] = 1;
doc["filename"] = filename;
mongoCollection.Save(doc);
}
/// <summary>
/// 獲取GridFS方式存儲(chǔ)的圖片
/// </summary>
public byte[] GetImgGridFS()
{
Document doc = mongoCollection.FindOne(new Document { { "ID", 1 } });
string filename = doc["filename"].ToString();
return GridFsRead(filename);
}
三、小結(jié)
文件存取應(yīng)該不是很難,值得注意的地方是:用第一種方式從文檔中讀出二進(jìn)制數(shù)據(jù)時(shí),一定要將類型轉(zhuǎn)換為“Binary”類型;還有系統(tǒng)自帶的鍵“_id”,它也不是string類型,是“Oid”類型的。
作者:李盼(Lipan)
出處:[Lipan] (http://www.cnblogs.com/lipan/)
- MongoDB 學(xué)習(xí)筆記(一)-MongoDB配置
- MongoDB學(xué)習(xí)筆記(六) MongoDB索引用法和效率分析
- MongoDB學(xué)習(xí)筆記之分組(group)使用示例
- MongoDB學(xué)習(xí)筆記—Linux下搭建MongoDB環(huán)境
- MongoDB學(xué)習(xí)筆記(一) MongoDB介紹與安裝方法
- MongoDB學(xué)習(xí)筆記(三) 在MVC模式下通過(guò)Jqgrid表格操作MongoDB數(shù)據(jù)
- MongoDB學(xué)習(xí)筆記(四) 用MongoDB的文檔結(jié)構(gòu)描述數(shù)據(jù)關(guān)系
- MongoDB學(xué)習(xí)筆記(二) 通過(guò)samus驅(qū)動(dòng)實(shí)現(xiàn)基本數(shù)據(jù)操作
- Windows下MongoDB的下載安裝、環(huán)境配置教程圖解
- MongoDB的下載、安裝與部署方法
- MongoDB系列教程(三):Windows中下載和安裝MongoDB
- mongodb數(shù)據(jù)庫(kù)入門(mén)學(xué)習(xí)筆記之下載、安裝、啟動(dòng)、連接操作解析
相關(guān)文章
Webservice遠(yuǎn)程調(diào)試及超時(shí)操作原理解析
這篇文章主要介紹了Webservice遠(yuǎn)程調(diào)試及超時(shí)操作原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07win2003服務(wù)器一招廢掉所有木馬(防提權(quán))
木馬的危害,在于它能夠遠(yuǎn)程控制你的電腦。當(dāng)你成為“肉雞”的時(shí)候,別人(控制端)就可以進(jìn)入你的電腦,偷看你的文件、盜竊密碼、甚至用你的QQ發(fā)一些亂七八糟的東西給你的好友2012-03-03MIME類型大全(response.setContentType中MIME參數(shù)類型總結(jié))
MIME類型就是設(shè)定某種擴(kuò)展名的文件用一種應(yīng)用程序來(lái)打開(kāi)的方式類型,當(dāng)該擴(kuò)展名文件被訪問(wèn)的時(shí)候,瀏覽器會(huì)自動(dòng)使用指定應(yīng)用程序來(lái)打開(kāi)。多用于指定一些客戶端自定義的文件名,以及一些媒體文件打開(kāi)方式2017-07-07在Mac OS X中配置Apache+PHP+MySQL運(yùn)行環(huán)境的詳細(xì)步驟
這篇文章主要介紹了在Mac OS X中配置Apache+PHP+MySQL運(yùn)行環(huán)境的詳細(xì)步驟,需要的朋友可以參考下2017-09-09一文詳解如何解決version?GLIBCXX_3.4.29?not?found問(wèn)題
這篇文章主要給大家介紹了關(guān)于如何解決version?GLIBCXX_3.4.29?not?found問(wèn)題的相關(guān)資料,文中通過(guò)圖文以及代碼代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01設(shè)置好的iis服務(wù)器怎么打開(kāi)網(wǎng)頁(yè)(圖文詳解)
讓自己電腦上的網(wǎng)頁(yè)在局域網(wǎng)中可以訪問(wèn)到,就需要我們使用IIS服務(wù)器,將網(wǎng)頁(yè)添加到服務(wù)器上的網(wǎng)站,那么設(shè)置好IIS服務(wù)器之后怎樣在瀏覽器中進(jìn)行訪問(wèn)呢,下面跟隨腳本之家小編一起學(xué)習(xí)吧2016-11-11