asp.net core集成MongoDB的完整步驟
一、前言及MongoDB的介紹
最近在整合自己的框架,順便把MongoDBD的最簡(jiǎn)單CRUD重構(gòu)一下作為組件化集成到asp.net core項(xiàng)目中,當(dāng)然此篇文章中沒(méi)有講解mongodb的集群部署,等有機(jī)會(huì)分享一下。
首先,我們?cè)贛ongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅(qū)動(dòng)是支持.Net Core 2.0的。

針對(duì)MongoDB,我想大家應(yīng)該不陌生,沒(méi)有用過(guò)也有聽(tīng)過(guò)。
1、mongodb是什么?
MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù),為web應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案,介于關(guān)系型數(shù)據(jù)庫(kù)和非關(guān)系型數(shù)據(jù)庫(kù)的產(chǎn)品,是非關(guān)系型數(shù)據(jù)庫(kù)中功能最豐富的。針對(duì)于數(shù)據(jù)處理是一把利器。
2、什么是關(guān)系型數(shù)據(jù)庫(kù)和非關(guān)系型數(shù)據(jù)庫(kù)?
關(guān)系型數(shù)據(jù)庫(kù):在我們所用過(guò)的sqlserver、mysql等,這些都是關(guān)系型數(shù)據(jù)庫(kù),并且關(guān)系型數(shù)據(jù)庫(kù)是遵循ACID原則的,嚴(yán)格的一致性。
非關(guān)系型數(shù)據(jù)庫(kù):也叫作NoSQL,用與超大規(guī)模數(shù)據(jù)的存儲(chǔ),這些類型的數(shù)據(jù)存儲(chǔ)不需要固定的模式,無(wú)需多余的操作就可以橫向擴(kuò)展。
3、RDBMS VS NoSQL
RDBMS:
高度組織結(jié)構(gòu)化數(shù)據(jù)
結(jié)構(gòu)化查詢語(yǔ)言
數(shù)據(jù)和關(guān)系都存儲(chǔ)在單獨(dú)的表中
嚴(yán)格一致性
基礎(chǔ)事務(wù)
NoSQL:
沒(méi)有聲明性查詢語(yǔ)言
鍵-值對(duì)存儲(chǔ),列存儲(chǔ)、文檔存儲(chǔ)等
最終一致性
非結(jié)構(gòu)化和不可預(yù)知數(shù)據(jù)
CAP定理、高可用、高性能、高擴(kuò)展
我相信講到這里,眼尖的同學(xué)應(yīng)該有注意到 CAP定理和最終一致性,肯定會(huì)聯(lián)想到 分布式系統(tǒng),在這里給你大大的一個(gè)贊。在分布式系統(tǒng)中可以完美的結(jié)合nosql,提高我們的性能。
4、介紹一下RDBMS與Mongodb的一些概念,有助于幫助大家理解

翻譯一下,即如下:

二、asp.net core集成mongoDB
1、為了演示方便我下載了 windows版本的mongodb server
大家可以自行去官網(wǎng)下載,然后針對(duì)于可視化界面,我采用了 Robo 3T 這個(gè)工具。很簡(jiǎn)潔美觀的可視化工具。推薦大家使用。
安裝結(jié)束后會(huì)在windows服務(wù)中看到mongodb server

然后我們打開(kāi)一下Robo 3T,連接我們的mongodb。

2、開(kāi)始在項(xiàng)目中配置一下我們的mongodb吧
第一步:我新建一個(gè)Core2.0類庫(kù)
引入了 “MongoDB.Driver” 這個(gè)nuget包。
然后擴(kuò)展了 Startup.cs 中的Services的擴(kuò)展方法
//擴(kuò)展方法public static class ServiceCollectionExtensions
{
public static void AddMongoDB(this IServiceCollection services, IConfiguration configuration)
{
services.Configure<Settings>(options =>
{
options.ConnectionString = configuration.GetSection("MongoConnection:ConnectionString").Value;
options.Database = configuration.GetSection("MongoConnection:Database").Value;
});
}
}
第二步:重構(gòu)封裝了mongodb的CRUD類,此處大家可以自行封裝,只展示了查找和新增。
public class MongoDBBase
{
private readonly IMongoDatabase _database = null;
public MongoDBBase(string connectionString, string databaseName)
{
var client = new MongoClient(connectionString);
if (client != null)
{
_database = client.GetDatabase(databaseName);
}
}
#region SELECT
/// <summary>
/// 根據(jù)查詢條件,獲取數(shù)據(jù)
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="id"></param>
/// <returns></returns>
public List<T> GetList<T>(Expression<Func<T, bool>> conditions = null)
{
var collection = _database.GetCollection<T>(typeof(T).Name);
if (conditions != null)
{
return collection.Find(conditions).ToList();
}
return collection.Find(_ => true).ToList();
}#endregion
#region INSERT/// <summary>
/// 插入多條數(shù)據(jù),數(shù)據(jù)用list表示
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="list"></param>
/// <returns></returns>
public List<T> InsertMany<T>(List<T> list)
{
var collection = _database.GetCollection<T>(typeof(T).Name);
collection.InsertMany(list);
return list;
}
#endregion
}
第三步:新建一個(gè)asp.net core webapi 項(xiàng)目,引用此類庫(kù)進(jìn)行演示
在項(xiàng)目中的 appsetting.json 添加 mongodb的連接字符串:我在這邊使用自定義的一個(gè)數(shù)據(jù)名稱 testdb,在插入mongodb的時(shí)候會(huì)會(huì)自動(dòng)在創(chuàng)建數(shù)據(jù)庫(kù)和集合以及文檔。接著往下看
"MongoConnection": { //mongodb數(shù)據(jù)庫(kù)連接
"ConnectionString": "mongodb://127.0.0.1:27017",
"Database": "testdb",
"IsSSL": true
},
第四步:新建一個(gè)mongodb測(cè)試控制器,展示了插入單條和多條以及查詢的接口。
[Produces("application/json")]
[Route("api/MongoDB/[action]")]
public class MongoDBController : Controller
{
private readonly MongoDBBase _context = null;
public MongoDBController(IOptions<Settings> settings)
{
_context = new MongoDBBase(settings.Value.ConnectionString, settings.Value.Database);
}
[HttpGet]
public IActionResult AddList()
{
List<MongoDBPostTest> list = new List<MongoDBPostTest>()
{
new MongoDBPostTest()
{
Id = "2",
Body = "Test note 3",
UpdatedOn = DateTime.Now,
UserId = 1,
HeaderImage = new NoteImage
{
ImageSize = 10,
Url = "http://localhost/image1.png",
ThumbnailUrl = "http://localhost/image1_small.png"
}
},
new MongoDBPostTest()
{
Id = "3",
Body = "Test note 4",
UpdatedOn = DateTime.Now,
UserId = 1,
HeaderImage = new NoteImage
{
ImageSize = 14,
Url = "http://localhost/image3.png",
ThumbnailUrl = "http://localhost/image3_small.png"
}
}
};
try
{
_context.InsertMany(list);
}
catch (Exception ex)
{
throw;
}
return Ok("成功");
}
[HttpGet]
public Result<List<MongoDBPostTest>> SelectSingle()
{
//無(wú)條件
var list = _context.GetList<MongoDBPostTest>();
//有條件
//var list = _context.GetList<MongoDBPostTest>(a => a.Id == "1");
//得到單條數(shù)據(jù),無(wú)條件
//var list = _context.GetSingle<MongoDBPostTest>();
//得到單條數(shù)據(jù),有條件
//var list = _context.GetSingle<MongoDBPostTest>(a => a.Id == "3");
ObjectId internalId = _context.GetInternalId("5bbf41651d3b66668cbb5bfc");
var a = _context.GetSingle<MongoDBPostTest>(note => note.Id == "5bbf41651d3b66668cbb5bfc" || note.InternalId == internalId);
return ResHelper.Suc(1, list, "成功");
}
}
測(cè)試類
public class MongoDBPostTest
{
[BsonId]
// standard BSonId generated by MongoDb
public ObjectId InternalId { get; set; }
public string Id { get; set; }
public string Body { get; set; } = string.Empty;
[BsonDateTimeOptions]
public DateTime UpdatedOn { get; set; } = DateTime.Now;
public NoteImage HeaderImage { get; set; }
public int UserId { get; set; } = 0;
}
public class NoteImage
{
public string Url { get; set; } = string.Empty;
public string ThumbnailUrl { get; set; } = string.Empty;
public long ImageSize { get; set; } = 0L;
}
第五步:運(yùn)行項(xiàng)目,執(zhí)行一下。
我們執(zhí)行一下插入多條的數(shù)據(jù)吧,執(zhí)行成功。

然后我們看一下數(shù)據(jù)庫(kù),發(fā)現(xiàn)已經(jīng)生成了一個(gè) testdb 數(shù)據(jù)庫(kù),里面包含了我們的數(shù)據(jù)內(nèi)容

然后我們執(zhí)行以下查的操作:把我們剛才插入的數(shù)據(jù)返回回來(lái)了。

注意:這邊有一個(gè)坑有待解決,就是mongodb存儲(chǔ)的時(shí)間是UTC,會(huì)跟我們的本地時(shí)間相差8個(gè)小時(shí)。因此這邊需要特殊處理一下時(shí)間。
三、總結(jié)
至此,mongodb的簡(jiǎn)單運(yùn)用已演示完畢,后期大家根據(jù)官方文檔可進(jìn)行擴(kuò)展,越擴(kuò)展到后面,會(huì)覺(jué)得越來(lái)越有意思。感謝大家的支持。Thank you。
參考文檔:
mongodb教程:http://www.runoob.com/mongodb/mongodb-tutorial.html
mongodb中文手冊(cè):http://www.mongoing.com/docs/
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
詳解如何在ASP.NET Core中應(yīng)用Entity Framework
本篇文章主要介紹了如何在ASP.NET Core中應(yīng)用Entity Framework,具有一定的參考價(jià)值,有興趣的可以一起了解一下。2016-12-12
asp.net 動(dòng)態(tài)表單之?dāng)?shù)據(jù)分頁(yè)
我們很常會(huì)在項(xiàng)目中提到一個(gè)動(dòng)態(tài)表單的概念,比如學(xué)校里面學(xué)生的考試成績(jī),當(dāng)學(xué)生登錄系統(tǒng)的時(shí)候,他當(dāng)然是希望看到他自己所有科目的成績(jī);又或者是班主任,他需要看到本班同學(xué)所有科目的成績(jī);這些時(shí)候我們一般都會(huì)在頁(yè)面中呈現(xiàn)如下的效果。2010-03-03
WEB在模態(tài)窗體里導(dǎo)出或下載文件功能代碼
實(shí)現(xiàn)在模態(tài)窗體里導(dǎo)出或下載文件,具體功能代碼如下,感興趣的朋友可以參考下哈2013-06-06
ASP.NET Core應(yīng)用錯(cuò)誤處理之三種呈現(xiàn)錯(cuò)誤頁(yè)面的方式
這篇文章主要給大家介紹了關(guān)于ASP.NET Core應(yīng)用錯(cuò)誤處理之三種呈現(xiàn)錯(cuò)誤頁(yè)面的方式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
asp.net配置會(huì)話狀態(tài)Session實(shí)現(xiàn)代碼
在Web應(yīng)用程序中,都會(huì)有一個(gè)Web.config文件來(lái)配置當(dāng)前Web項(xiàng)目。其中包括關(guān)于會(huì)話狀態(tài)Session的配置2012-10-10
asp.net下比較兩個(gè)等長(zhǎng)字符串是否含有完全相同字符(忽略字符順序)
項(xiàng)目中遇到一個(gè)好玩的問(wèn)題,需要比較兩個(gè)選擇區(qū)域選擇的文字是否一樣,就想到將這兩個(gè)區(qū)域中選中的文字鏈接起來(lái)進(jìn)行兩個(gè)字符串之間的比較2010-06-06
詳解Asp.net Core 使用Redis存儲(chǔ)Session
本篇文章主要介紹了Asp.net Core 使用Redis存儲(chǔ)Session ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。2016-12-12
微信JS-SDK分享功能的.Net實(shí)現(xiàn)代碼
這篇文章主要介紹了微信JS-SDK分享功能的.Net實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-09-09

