asp.net core集成MongoDB的完整步驟
一、前言及MongoDB的介紹
最近在整合自己的框架,順便把MongoDBD的最簡單CRUD重構(gòu)一下作為組件化集成到asp.net core項目中,當(dāng)然此篇文章中沒有講解mongodb的集群部署,等有機會分享一下。
首先,我們在MongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅(qū)動是支持.Net Core 2.0的。
針對MongoDB,我想大家應(yīng)該不陌生,沒有用過也有聽過。
1、mongodb是什么?
MongoDB是一個基于分布式文件存儲的數(shù)據(jù)庫,為web應(yīng)用提供可擴展的高性能數(shù)據(jù)存儲解決方案,介于關(guān)系型數(shù)據(jù)庫和非關(guān)系型數(shù)據(jù)庫的產(chǎn)品,是非關(guān)系型數(shù)據(jù)庫中功能最豐富的。針對于數(shù)據(jù)處理是一把利器。
2、什么是關(guān)系型數(shù)據(jù)庫和非關(guān)系型數(shù)據(jù)庫?
關(guān)系型數(shù)據(jù)庫:在我們所用過的sqlserver、mysql等,這些都是關(guān)系型數(shù)據(jù)庫,并且關(guān)系型數(shù)據(jù)庫是遵循ACID原則的,嚴(yán)格的一致性。
非關(guān)系型數(shù)據(jù)庫:也叫作NoSQL,用與超大規(guī)模數(shù)據(jù)的存儲,這些類型的數(shù)據(jù)存儲不需要固定的模式,無需多余的操作就可以橫向擴展。
3、RDBMS VS NoSQL
RDBMS:
高度組織結(jié)構(gòu)化數(shù)據(jù)
結(jié)構(gòu)化查詢語言
數(shù)據(jù)和關(guān)系都存儲在單獨的表中
嚴(yán)格一致性
基礎(chǔ)事務(wù)
NoSQL:
沒有聲明性查詢語言
鍵-值對存儲,列存儲、文檔存儲等
最終一致性
非結(jié)構(gòu)化和不可預(yù)知數(shù)據(jù)
CAP定理、高可用、高性能、高擴展
我相信講到這里,眼尖的同學(xué)應(yīng)該有注意到 CAP定理和最終一致性,肯定會聯(lián)想到 分布式系統(tǒng),在這里給你大大的一個贊。在分布式系統(tǒng)中可以完美的結(jié)合nosql,提高我們的性能。
4、介紹一下RDBMS與Mongodb的一些概念,有助于幫助大家理解
翻譯一下,即如下:
二、asp.net core集成mongoDB
1、為了演示方便我下載了 windows版本的mongodb server
大家可以自行去官網(wǎng)下載,然后針對于可視化界面,我采用了 Robo 3T 這個工具。很簡潔美觀的可視化工具。推薦大家使用。
安裝結(jié)束后會在windows服務(wù)中看到mongodb server
然后我們打開一下Robo 3T,連接我們的mongodb。
2、開始在項目中配置一下我們的mongodb吧
第一步:我新建一個Core2.0類庫
引入了 “MongoDB.Driver” 這個nuget包。
然后擴展了 Startup.cs 中的Services的擴展方法
//擴展方法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 }
第三步:新建一個asp.net core webapi 項目,引用此類庫進行演示
在項目中的 appsetting.json 添加 mongodb的連接字符串:我在這邊使用自定義的一個數(shù)據(jù)名稱 testdb,在插入mongodb的時候會會自動在創(chuàng)建數(shù)據(jù)庫和集合以及文檔。接著往下看
"MongoConnection": { //mongodb數(shù)據(jù)庫連接 "ConnectionString": "mongodb://127.0.0.1:27017", "Database": "testdb", "IsSSL": true },
第四步:新建一個mongodb測試控制器,展示了插入單條和多條以及查詢的接口。
[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() { //無條件 var list = _context.GetList<MongoDBPostTest>(); //有條件 //var list = _context.GetList<MongoDBPostTest>(a => a.Id == "1"); //得到單條數(shù)據(jù),無條件 //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, "成功"); } }
測試類
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; }
第五步:運行項目,執(zhí)行一下。
我們執(zhí)行一下插入多條的數(shù)據(jù)吧,執(zhí)行成功。
然后我們看一下數(shù)據(jù)庫,發(fā)現(xiàn)已經(jīng)生成了一個 testdb 數(shù)據(jù)庫,里面包含了我們的數(shù)據(jù)內(nèi)容
然后我們執(zhí)行以下查的操作:把我們剛才插入的數(shù)據(jù)返回回來了。
注意:這邊有一個坑有待解決,就是mongodb存儲的時間是UTC,會跟我們的本地時間相差8個小時。因此這邊需要特殊處理一下時間。
三、總結(jié)
至此,mongodb的簡單運用已演示完畢,后期大家根據(jù)官方文檔可進行擴展,越擴展到后面,會覺得越來越有意思。感謝大家的支持。Thank you。
參考文檔:
mongodb教程:http://www.runoob.com/mongodb/mongodb-tutorial.html
mongodb中文手冊:http://www.mongoing.com/docs/
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
彈出窗口,點擊確定在刪除數(shù)據(jù)的實現(xiàn)方法
彈出窗口,點擊確定在刪除數(shù)據(jù)的實現(xiàn)方法,需要的朋友可以參考一下2013-04-04自寫一個模仿Dictionary與Foreach的實現(xiàn)及心得總結(jié)
利用閑暇時間自己寫一個類模仿Dictionary實現(xiàn),如果一個類進行foreach的話,該類必須實現(xiàn)IEnumerable,集合要支持foreach方式的遍歷,必須實現(xiàn)IEnumerable接口,感興趣的你可不要錯過了哈2013-02-02URL重寫及干掉ASP.NET試圖狀態(tài)的實現(xiàn)方法
URL重寫已經(jīng)很普遍了,但基本上大部分的URL重寫都不支持頁面的相對路徑,所有如果想在已經(jīng)開發(fā)好的項目中添加還是有壓力的,第二就是例如微軟的那個URL重寫是根據(jù)正則表達式來處理的,那樣是很好,但也有不足之處,就是不方便定位到某個頁面只能有哪些參數(shù)2011-11-11ASP.NET實現(xiàn)數(shù)據(jù)的添加(第10節(jié))
這篇文章主要介紹了ASP.NET如何實現(xiàn)數(shù)據(jù)的添加,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-08-08Asp.net webForm設(shè)置允許表單提交Html的方法
下面小編就為大家分享一篇Asp.net webForm設(shè)置允許表單提交Html的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12ASP.Net中數(shù)據(jù)展示控件的嵌套使用示例
ASP.Net中數(shù)據(jù)展示控件的嵌套使用,在Repeater里面嵌套一個GridView,將每個User的任務(wù)展示出來2014-09-09