• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

    asp.net core集成MongoDB的完整步驟

    來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:34:44
    文檔

    asp.net core集成MongoDB的完整步驟

    asp.net core集成MongoDB的完整步驟:一、前言及MongoDB的介紹 最近在整合自己的框架,順便把MongoDBD的最簡單CRUD重構(gòu)一下作為組件化集成到asp.net core項(xiàng)目中,當(dāng)然此篇文章中沒有講解mongodb的集群部署,等有機(jī)會(huì)分享一下。 首先,我們在MongoDB的官方文檔中看到,MongoDb的2.4以上
    推薦度:
    導(dǎo)讀asp.net core集成MongoDB的完整步驟:一、前言及MongoDB的介紹 最近在整合自己的框架,順便把MongoDBD的最簡單CRUD重構(gòu)一下作為組件化集成到asp.net core項(xiàng)目中,當(dāng)然此篇文章中沒有講解mongodb的集群部署,等有機(jī)會(huì)分享一下。 首先,我們在MongoDB的官方文檔中看到,MongoDb的2.4以上

    一、前言及MongoDB的介紹

    最近在整合自己的框架,順便把MongoDBD的最簡單CRUD重構(gòu)一下作為組件化集成到asp.net core項(xiàng)目中,當(dāng)然此篇文章中沒有講解mongodb的集群部署,等有機(jī)會(huì)分享一下。

    首先,我們在MongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅(qū)動(dòng)是支持.Net Core 2.0的。

    針對MongoDB,我想大家應(yīng)該不陌生,沒有用過也有聽過。

    1、mongodb是什么?

    MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫,為web應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案,介于關(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ù)的存儲(chǔ),這些類型的數(shù)據(jù)存儲(chǔ)不需要固定的模式,無需多余的操作就可以橫向擴(kuò)展。

    3、RDBMS VS NoSQL

    RDBMS:

      高度組織結(jié)構(gòu)化數(shù)據(jù)

      結(jié)構(gòu)化查詢語言

      數(shù)據(jù)和關(guān)系都存儲(chǔ)在單獨(dú)的表中

      嚴(yán)格一致性

      基礎(chǔ)事務(wù)

    NoSQL:

      沒有聲明性查詢語言

      鍵-值對存儲(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)下載,然后針對于可視化界面,我采用了 Robo 3T 這個(gè)工具。很簡潔美觀的可視化工具。推薦大家使用。

    安裝結(jié)束后會(huì)在windows服務(wù)中看到mongodb server

    然后我們打開一下Robo 3T,連接我們的mongodb。

    2、開始在項(xiàng)目中配置一下我們的mongodb吧

    第一步:我新建一個(gè)Core2.0類庫

    引入了 “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)目,引用此類庫進(jìn)行演示

    在項(xiàng)目中的 appsetting.json 添加 mongodb的連接字符串:我在這邊使用自定義的一個(gè)數(shù)據(jù)名稱 testdb,在插入mongodb的時(shí)候會(huì)會(huì)自動(dòng)在創(chuàng)建數(shù)據(jù)庫和集合以及文檔。接著往下看

     "MongoConnection": { //mongodb數(shù)據(jù)庫連接
     "ConnectionString": "mongodb://127.0.0.1:27017",
     "Database": "testdb",
     "IsSSL": true
     },

    第四步:新建一個(gè)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;
     }

    第五步:運(yùn)行項(xiàng)目,執(zhí)行一下。

    我們執(zhí)行一下插入多條的數(shù)據(jù)吧,執(zhí)行成功。

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

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

    注意:這邊有一個(gè)坑有待解決,就是mongodb存儲(chǔ)的時(shí)間是UTC,會(huì)跟我們的本地時(shí)間相差8個(gè)小時(shí)。因此這邊需要特殊處理一下時(shí)間。

    三、總結(jié)

    至此,mongodb的簡單運(yùn)用已演示完畢,后期大家根據(jù)官方文檔可進(jìn)行擴(kuò)展,越擴(kuò)展到后面,會(huì)覺得越來越有意思。感謝大家的支持。Thank you。

    參考文檔:

    mongodb教程:http://www.runoob.com/mongodb/mongodb-tutorial.html

    mongodb中文手冊:http://www.mongoing.com/docs/

    好了,

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    asp.net core集成MongoDB的完整步驟

    asp.net core集成MongoDB的完整步驟:一、前言及MongoDB的介紹 最近在整合自己的框架,順便把MongoDBD的最簡單CRUD重構(gòu)一下作為組件化集成到asp.net core項(xiàng)目中,當(dāng)然此篇文章中沒有講解mongodb的集群部署,等有機(jī)會(huì)分享一下。 首先,我們在MongoDB的官方文檔中看到,MongoDb的2.4以上
    推薦度:
    標(biāo)簽: 步驟 的步驟 net
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 精品免费久久久久国产一区| 亚洲精品久久久www| 国自产精品手机在线观看视频| 久久精品黄AA片一区二区三区| 国产午夜精品一区二区三区小说 | 亚洲国产小视频精品久久久三级 | 日韩精品毛片| 精品无人区麻豆乱码1区2区 | 午夜不卡久久精品无码免费| 精品国产福利盛宴在线观看| 精品三级在线观看| jizz国产精品网站| 亚洲日韩国产精品第一页一区| 久久99精品国产麻豆婷婷| 99久久国产综合精品五月天喷水 | 国产午夜无码精品免费看动漫| 亚洲精品永久在线观看| 欧美精品成人3d在线| 国产区精品高清在线观看| 亚洲欧美日韩精品久久| 国产精品免费精品自在线观看| 国产精品无码无需播放器| 无码aⅴ精品一区二区三区浪潮| 亚洲а∨天堂久久精品9966| 蜜臀AV无码国产精品色午夜麻豆| 国产亚洲午夜高清国产拍精品| 国产成人无码精品一区在线观看 | 欧美精品免费在线| 99精品视频3| 99re6在线视频精品免费| 国产伦精品免编号公布| 久久亚洲私人国产精品| 欧美精品欧美人与动人物牲交| 四虎国产精品永久在线观看| 亚洲av成人无码久久精品| 亚洲国产精品成人精品无码区 | 蜜臀久久99精品久久久久久| 久久久久人妻一区精品| 亚洲国产成人乱码精品女人久久久不卡| 免费视频精品一区二区三区| 94久久国产乱子伦精品免费 |