<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        .net Core連接MongoDB數據庫的步驟詳解

        來源:懂視網 責編:小采 時間:2020-11-27 22:35:10
        文檔

        .net Core連接MongoDB數據庫的步驟詳解

        .net Core連接MongoDB數據庫的步驟詳解:前言 前兩天在學習MongoDB相關的知識,做了個小Demo,做的是省份下面有多少所學校,嗯,做的比較粗暴。 我們在MongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅動是支持.Net Core 2.0的。 所以,在我們安裝好了MangoDB后,就可以開始M
        推薦度:
        導讀.net Core連接MongoDB數據庫的步驟詳解:前言 前兩天在學習MongoDB相關的知識,做了個小Demo,做的是省份下面有多少所學校,嗯,做的比較粗暴。 我們在MongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅動是支持.Net Core 2.0的。 所以,在我們安裝好了MangoDB后,就可以開始M

        前言

        前兩天在學習MongoDB相關的知識,做了個小Demo,做的是省份下面有多少所學校,嗯,做的比較粗暴。。

        我們在MongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅動是支持.Net Core 2.0的。

        所以,在我們安裝好了MangoDB后,就可以開始MangoDB的.Net之旅了。

        方法如下:

        連接MongoDB首先要通過Nuget添加一個MongoDB的包,下載此包

        安裝完畢后開始寫代碼了,創建一個省份實體,一個學校實體

        using MongoDB.Bson.Serialization.Attributes;using System.Collections.Generic;
        namespace MongoCore.Models
        {
         public class Province
         {
         [BsonId]
         public int ProvinceID { get; set; }
        
         public string ProvinceName { get; set; }
         /// <summary>
         /// 省份里有多個學校 這里用集合保存
         /// </summary>
         public IList<School> SchoolName { get; set; }
         }
        }
        
        namespace MongoCore.Models
        { //用于后面添加學校 public School(string schoolName, string years) { SchoolName = schoolName; Years = years; }
         public class School
         {
         public string SchoolName { get; set; }
         public string Years { get; set; }
         }
        }

        創建上下文類,連接MongoDB

        namespace MongoCore.Models
        {
         public class ProvinceContext
         {
         //定義數據庫
         private readonly IMongoDatabase _database = null;
         public ProvinceContext()
         {
         //連接服務器名稱 mongo的默認端口27017
         var client = new MongoClient("mongodb://.......:27017");
         if (client != null)
         //連接數據庫
         _database = client.GetDatabase("數據庫名");
         }
        
         public IMongoCollection<Province> Province
         {
         get
         {
         return _database.GetCollection<Province>("Province");
         }
         }
         }
        }

        創建控制器

        private readonly ProvinceContext _context = new ProvinceContext();
         public async Task<IActionResult> Index()
         {
         var list = await _context.Province.Find(_ => true).ToListAsync();
         return View(list);
         }

        視圖

        @model List<MongoCore.Models.Province>
        @{
         ViewData["Title"] = "Index";
        }
        <h2>Index</h2>
        <h2>Index</h2>
        <a asp-action="Create"><input type="button" value="新 建" class="btn btn-default" /></a>
        <table class="table">
         <tr>
         <th>省份ID</th>
         <th>省份名稱</th>
         <th>操作</th>
         </tr>
         @foreach (var item in Model)
         {
         <tr>
         <td>
         @Html.DisplayFor(modelItem => item.ProvinceID)
         </td>
         <td>
         @Html.DisplayFor(modelItem => item.ProvinceName)
         </td>
         <td>
         <a asp-action="Insert" asp-route-ProvinceID="@item.ProvinceID">新 增</a>  
         <a asp-action="Detail" asp-route-ProvinceID="@item.ProvinceID">詳 情</a>  
         <a asp-action="Delete" asp-route-ProvinceID="@item.ProvinceID">刪 除</a>  
         </td>
         </tr>
         }
        </table>

        運行的時候修改配置在Startup.cs里

        運行效果是這樣的,現在還沒有數據,

        點擊新建按鈕添加省份,這里我添加了湖北省

        添加省份代碼如下:后端

        public IActionResult Create()
         {
         return View();
         }
         [HttpPost]
         [ValidateAntiForgeryToken]
         public async Task<ActionResult> Create(Province item)
         {
         try
         {
         //初始化學校類型數據
         item.SchoolName = new List<School>();
         await _context.Province.InsertOneAsync(item);
         return RedirectToAction(nameof(Index));
         }
         catch
         {
         return View();
         }
         }

        視圖:

        @model MongoCore.Models.Province
        @{
         ViewData["Title"] = "Create";
        }
        
        <h2>Create</h2>
        <div class="row">
         <div class="col-md-4">
         <form asp-action="Create">
         <div asp-validation-summary="ModelOnly" class="text-danger"></div>
         <div class="form-group">
         <label class="control-label">省份ID</label>
         <input asp-for="ProvinceID" class="form-control" />
         </div>
         <div class="form-group">
         <label class="control-label">省份名稱</label>
         <input asp-for="ProvinceName" class="form-control" />
         </div>
         <div class="form-group">
         <input type="submit" value="保 存" class="btn btn-default" />
         </div>
         </form>
         </div>
        </div>

        接下來就是添加省份下面的學校了

        public async Task<IActionResult> Insert(int ProvinceID)
         {
         var num = await _context.Province.Find(p => p.ProvinceID == ProvinceID).SingleOrDefaultAsync();
         return View(num);
         }
         
         [HttpPost]
         [ValidateAntiForgeryToken]
         public async Task<IActionResult> Insert(int ProvinceID, string Years, string SchoolName)
         {
         var item = await _context.Province.Find(p => p.ProvinceID == ProvinceID).SingleOrDefaultAsync();
         School sl = new School(SchoolName,Years);
         //添加學校
         item.SchoolName.Add(sl);
         //更新
         ReplaceOneResult actionResult
         = await _context.Province
         .ReplaceOneAsync(n => n.ProvinceID.Equals(ProvinceID)
         , item
         , new UpdateOptions { IsUpsert = true });
         return RedirectToAction(nameof(Index));
         }

        視圖:

        @model MongoCore.Models.Province
        @{
         ViewData["Title"] = "Insert";
        }
        <h2>新增</h2>
        <div class="row">
         <div class="col-md-4">
         <form asp-action="Insert">
         <div asp-validation-summary="ModelOnly" class="text-danger"></div>
         <input type="hidden" asp-for="ProvinceID" />
         <div class="form-group">
         <label class="control-label">學校名稱</label>
         <input name="SchoolName" class="form-control" />
         </div>
         <div class="form-group">
         <label class="control-label">成立年份</label>
         <input name="Years" class="form-control" />
         </div>
         <div class="form-group">
         <input type="submit" value="保 存" class="btn btn-default" />
         </div>
         </form>
         </div>
        </div>

        然后添加學校,我添加了兩所學校,在MongoDB里可以看到數據

        總結

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        .net Core連接MongoDB數據庫的步驟詳解

        .net Core連接MongoDB數據庫的步驟詳解:前言 前兩天在學習MongoDB相關的知識,做了個小Demo,做的是省份下面有多少所學校,嗯,做的比較粗暴。 我們在MongoDB的官方文檔中看到,MongoDb的2.4以上的For .Net的驅動是支持.Net Core 2.0的。 所以,在我們安裝好了MangoDB后,就可以開始M
        推薦度:
        標簽: 步驟 方法 教程
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 久久精品国产免费观看三人同眠| 四虎国产精品成人免费久久 | 久久精品国产亚洲AV天海翼 | 偷自拍亚洲视频在线观看| www.999精品视频观看免费| 亚洲av无码片区一区二区三区| 精品福利一区二区三区免费视频| 亚洲熟妇av一区| 成人无码区免费A片视频WWW| 77777亚洲午夜久久多喷| 国产卡二卡三卡四卡免费网址| 亚洲综合激情五月丁香六月 | 亚洲中文无韩国r级电影| 中文在线观看免费网站| 亚洲国产另类久久久精品黑人 | 亚洲国产成人无码AV在线| 国产成人免费网站在线观看| 免费VA在线观看无码| 亚洲女同成av人片在线观看| 无码国产精品一区二区免费模式 | 日本高清在线免费| 亚洲熟妇丰满xxxxx| 亚洲国产精品第一区二区三区| 国产VA免费精品高清在线| 亚洲AV无码成人精品区在线观看| 亚洲无砖砖区免费| 亚洲av无码专区亚洲av不卡| 亚洲裸男gv网站| 精品无码国产污污污免费网站 | 亚洲伊人久久成综合人影院| 18禁超污无遮挡无码免费网站| 亚洲国产成人久久| jjzz亚洲亚洲女人| 18禁男女爽爽爽午夜网站免费| 亚洲一区二区无码偷拍| 狠狠亚洲狠狠欧洲2019| 91精品国产免费久久久久久青草| 美女被艹免费视频| 亚洲最大在线观看| 亚洲综合久久夜AV | 青青草a免费线观a|