婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MongoDB入門教程之C#驅動操作實例

MongoDB入門教程之C#驅動操作實例

熱門標簽:兗州電話外呼營銷系統 企業智能外呼系統價格多少 高德地圖標注商戶位置 徐州ai電銷機器人原理 智能電銷機器人銷售話術 南京400電話怎樣辦理 福州電銷機器人源代碼 沈陽營銷電銷機器人招商 機器人外呼系統軟件存在問題

作為系列的最后一篇,得要說說C#驅動對mongodb的操作,目前驅動有兩種:官方驅動和samus驅動,不過我個人還是喜歡后者,

因為提供了豐富的linq操作,相當方便。

官方驅動:https://github.com/mongodb/mongo-csharp-driver/downloads。下載后,還提供了一個酷似msdn的幫助文檔。

samus驅動:https://github.com/samus/mongodb-csharp/downloads。

下面就具體看看samus驅動,https://github.com/samus/mongodb-csharp/blob/master/examples/Simple/Main.cs上面提供了

一個簡單的demo,大體上看看我們就知道怎么玩了。

一: 實踐

1:我們建立一個Person實體,MongoAlias特性表示取別名,這里的ID值將會覆蓋掉數據庫自動生成的_id。

復制代碼 代碼如下:

#region 數據實體
    /// summary>
/// 數據實體
/// /summary>
    public class Person
    {
        [MongoAlias("_id")]
        public string ID { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }

        public DateTime CreateTime { get; set; }
    }
    #endregion

2:初始化一些變量

復制代碼 代碼如下:

string connectionString = string.Empty;

        string databaseName = string.Empty;

        string collectionName = string.Empty;

        static MongodbHelperT> mongodb;

        #region 初始化操作
/// summary>
/// 初始化操作
/// /summary>
        public MongodbHelper()
        {
            connectionString = "Server=127.0.0.1:2222";
            databaseName = "shopex";
            collectionName = "person";
        }
        #endregion

3:為了方便T的繼承類使用linq功能,我們還需要映射一下。

復制代碼 代碼如下:

#region 實現linq查詢的映射配置
        /// summary>
/// 實現linq查詢的映射配置
/// /summary>
        public MongoConfiguration configuration
        {
            get
            {
                var config = new MongoConfigurationBuilder();

                config.Mapping(mapping =>
                {
                    mapping.DefaultProfile(profile =>
                    {
                        profile.SubClassesAre(t => t.IsSubclassOf(typeof(T)));
                    });
                    mapping.MapT>();
                    mapping.MapT>();
                });

                config.ConnectionString(connectionString);

                return config.BuildConfiguration();
            }
        }
        #endregion

4:下面是一些基本的CURD的代碼,跟寫EF代碼很類似,寫起來好舒服。

復制代碼 代碼如下:

#region 插入操作
        /// summary>
/// 插入操作
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public void Insert(T t)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    collection.Insert(t, true);

                    mongo.Disconnect();

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 更新操作
        /// summary>
/// 更新操作
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public void Update(T t, ExpressionFuncT, bool>> func)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    collection.UpdateT>(t, func, true);

                    mongo.Disconnect();

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 獲取集合
        /// summary>
///獲取集合
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public ListT> List(int pageIndex, int pageSize, ExpressionFuncT, bool>> func, out int pageCount)
        {
            pageCount = 0;

            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    pageCount = Convert.ToInt32(collection.Count());

                    var personList = collection.Linq().Where(func).Skip(pageSize * (pageIndex - 1))
                                                   .Take(pageSize).Select(i => i).ToList();

                    mongo.Disconnect();

                    return personList;

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 讀取單條記錄
        /// summary>
///讀取單條記錄
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public T Single(ExpressionFuncT, bool>> func)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    var single = collection.Linq().FirstOrDefault(func);

                    mongo.Disconnect();

                    return single;

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 刪除操作
        /// summary>
/// 刪除操作
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public void Delete(ExpressionFuncT, bool>> func)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    //這個地方要注意,一定要加上T參數,否則會當作object類型處理
//導致刪除失敗
                    collection.RemoveT>(func);

                    mongo.Disconnect();

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

5.   好,我們開一下2222端口,由于前前篇我已經把這個mongodb做成了服務,現在就直接連過去了,并做一下對Name的索引。

6. 一切準備妥當,我們做下基本的操作,比如這里我添加一千條數據,注意我開啟的是安全模式,如果插入不成功,將會拋出異常。

 1> Add:

 

復制代碼 代碼如下:

 static void Main(string[] args)
        {
            MongodbHelperPerson> helper = new MongodbHelperPerson>();

            //插入1000條數據
            for (int i = 0; i 1000; i++)
            {
                helper.Insert(new Person()
                {
                    ID = Guid.NewGuid().ToString(),
                    Name = "jack" + i,
                    Age = i,
                    CreateTime = DateTime.Now
                });
            }

            Console.WriteLine("插入成功");

            Console.Read();
        }
 


 乍一看顯示的數據以為有問題,為什么沒有出現jack0或者jack999,不過find的一下后心情舒坦了。

2> update:   這里就把jack941的名字改掉“mary”

復制代碼 代碼如下:

static void Main(string[] args)
        {
            MongodbHelperPerson> helper = new MongodbHelperPerson>();

            //修改jack941改成mary
            var single = helper.Single(i => i.Name == "jack941");
            single.Name = "mary";
            helper.Update(single, i => i.ID == single.ID);

            Console.WriteLine("修改成功");
            Console.Read();
        }

3>Delete:  刪除mary這條記錄

復制代碼 代碼如下:

static void Main(string[] args)
        {
            MongodbHelperPerson> helper = new MongodbHelperPerson>();

            //刪除mary這個記錄
            helper.Delete(i => i.Name == "mary");

            Console.WriteLine("刪除成功");
            Console.Read();
        }

4> list操作: 這里我獲取一下名字里面帶9的人數列表

復制代碼 代碼如下:

static void Main(string[] args)
        {
            MongodbHelperPerson> helper = new MongodbHelperPerson>();

            int pagecount;

            //獲取名字里面帶9的人數
            var list = helper.List(1, 20, i => i.Name.Contains("9"), out pagecount);

           Console.Read();
        }

總的運行代碼

復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Configuration;
using System.Linq.Expressions;

using MongoDB.Configuration;
using MongoDB.Linq;
using MongoDB.Attributes;


namespace MongoDB.Test
{
    public class MongodbHelperT> where T : class
    {
        string connectionString = string.Empty;

        string databaseName = string.Empty;

        string collectionName = string.Empty;

        static MongodbHelperT> mongodb;

        #region 初始化操作
        /// summary>
/// 初始化操作
/// /summary>
        public MongodbHelper()
        {
            connectionString = "Server=127.0.0.1:2222";
            databaseName = "shopex";
            collectionName = "person";
        }
        #endregion

        #region 實現linq查詢的映射配置
        /// summary>
/// 實現linq查詢的映射配置
/// /summary>
        public MongoConfiguration configuration
        {
            get
            {
                var config = new MongoConfigurationBuilder();

                config.Mapping(mapping =>
                {
                    mapping.DefaultProfile(profile =>
                    {
                        profile.SubClassesAre(t => t.IsSubclassOf(typeof(T)));
                    });
                    mapping.MapT>();
                    mapping.MapT>();
                });

                config.ConnectionString(connectionString);

                return config.BuildConfiguration();
            }
        }
        #endregion

        #region 插入操作
        /// summary>
/// 插入操作
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public void Insert(T t)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    collection.Insert(t, true);

                    mongo.Disconnect();

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 更新操作
        /// summary>
/// 更新操作
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public void Update(T t, ExpressionFuncT, bool>> func)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    collection.UpdateT>(t, func, true);

                    mongo.Disconnect();

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 獲取集合
        /// summary>
///獲取集合
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public ListT> List(int pageIndex, int pageSize, ExpressionFuncT, bool>> func, out int pageCount)
        {
            pageCount = 0;

            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    pageCount = Convert.ToInt32(collection.Count());

                    var personList = collection.Linq().Where(func).Skip(pageSize * (pageIndex - 1))
                                                   .Take(pageSize).Select(i => i).ToList();

                    mongo.Disconnect();

                    return personList;

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 讀取單條記錄
        /// summary>
///讀取單條記錄
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public T Single(ExpressionFuncT, bool>> func)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    var single = collection.Linq().FirstOrDefault(func);

                    mongo.Disconnect();

                    return single;

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion

        #region 刪除操作
        /// summary>
/// 刪除操作
/// /summary>
/// param name="person">/param>
/// returns>/returns>
        public void Delete(ExpressionFuncT, bool>> func)
        {
            using (Mongo mongo = new Mongo(configuration))
            {
                try
                {
                    mongo.Connect();

                    var db = mongo.GetDatabase(databaseName);

                    var collection = db.GetCollectionT>(collectionName);

                    //這個地方要注意,一定要加上T參數,否則會當作object類型處理
//導致刪除失敗
                    collection.RemoveT>(func);

                    mongo.Disconnect();

                }
                catch (Exception)
                {
                    mongo.Disconnect();
                    throw;
                }
            }
        }
        #endregion
    }

    #region 數據實體
    /// summary>
/// 數據實體
/// /summary>
    public class Person
    {
        [MongoAlias("_id")]
        public string ID { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }

        public DateTime CreateTime { get; set; }
    }
    #endregion
}

您可能感興趣的文章:
  • C#簡單操作MongoDB的步驟全紀錄
  • C#中如何將MongoDB->RunCommand結果映射到業務類的方法總結
  • Mongodb在CSharp里實現Aggregate實例
  • MongoDB實現基于關鍵詞的文章檢索功能(C#版)
  • C#中使用1.7版本驅動操作MongoDB簡單例子
  • C# 對MongoDB 進行增刪改查的簡單操作實例
  • 關于C#生成MongoDB中ObjectId的實現方法
  • C#基于Mongo的官方驅動手擼一個Super簡易版MongoDB-ORM框架

標簽:本溪 丹東 吉安 邯鄲 景德鎮 昭通 鶴崗 大理

巨人網絡通訊聲明:本文標題《MongoDB入門教程之C#驅動操作實例》,本文關鍵詞  MongoDB,入門教程,之,驅動,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MongoDB入門教程之C#驅動操作實例》相關的同類信息!
  • 本頁收集關于MongoDB入門教程之C#驅動操作實例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩av电影一区| 一区二区三区免费看视频| 国内一区二区在线| 亚洲电影一级片| 成人免费一区二区三区视频| 久久久美女艺术照精彩视频福利播放 | 国产综合久久久久影院| 亚洲午夜私人影院| 亚洲激情中文1区| 亚洲精品中文在线观看| 中文字幕一区二区三| 中文字幕乱码一区二区免费| 久久久久国产成人精品亚洲午夜| 91麻豆精品国产91| 欧美一区二区视频网站| 欧美高清一级片在线| 4438x成人网最大色成网站| 欧美午夜理伦三级在线观看| 欧美在线视频不卡| 欧美福利视频一区| 3d动漫精品啪啪一区二区竹菊| 欧美疯狂性受xxxxx喷水图片| 88在线观看91蜜桃国自产| 51久久夜色精品国产麻豆| 日韩欧美中文字幕一区| 欧美成人欧美edvon| 国产亚洲精品bt天堂精选| 国产亚洲制服色| 亚洲天堂精品视频| 亚洲国产综合在线| 蜜桃视频在线观看一区| 国产在线视频精品一区| 不卡的av网站| 精品视频在线视频| 精品国产欧美一区二区| 中文字幕一区二区三区精华液 | 在线这里只有精品| 欧美乱熟臀69xxxxxx| 欧美草草影院在线视频| 国产精品私人影院| 亚洲欧美国产三级| 理论电影国产精品| 成人在线视频首页| 欧美日韩成人在线一区| 久久男人中文字幕资源站| 亚洲欧美日韩人成在线播放| 日韩国产精品久久久| 激情五月婷婷综合| 99久久精品免费精品国产| 欧美性大战久久久| 久久先锋影音av鲁色资源| 亚洲精品成a人| 国产主播一区二区三区| 在线免费av一区| 久久色视频免费观看| 一区二区三区在线不卡| 国产成人精品免费一区二区| 精品视频免费看| 中文字幕一区在线| 黑人巨大精品欧美一区| 欧美日韩亚洲高清一区二区| 日本一区二区久久| 九色|91porny| 欧美精选午夜久久久乱码6080| 国产精品全国免费观看高清| 久久精品国产99| 欧美这里有精品| 国产精品视频九色porn| 韩国女主播成人在线| 欧美电影一区二区| 亚洲永久免费av| 99国产精品久| 国产精品电影院| 国产精品99久久久久久久女警| 91精品欧美福利在线观看| 亚洲成人av一区二区三区| 99国产精品国产精品久久| 久久久精品tv| 国产美女一区二区| 久久综合九色综合欧美亚洲| 久久精品国产**网站演员| 91麻豆精品91久久久久同性| 亚洲电影视频在线| 欧美午夜一区二区三区| 亚洲精品成人精品456| 色狠狠桃花综合| 国产精品久久久久影视| 大尺度一区二区| 中文字幕乱码一区二区免费| 国产精品亚洲а∨天堂免在线| 欧美不卡视频一区| 蜜臀国产一区二区三区在线播放| 欧美一级二级三级乱码| 蜜桃av噜噜一区二区三区小说| 欧美卡1卡2卡| 麻豆国产精品777777在线| 欧美一区二区三区在线视频| 免费观看在线色综合| 欧美精品一区二区三| 国产成人av一区二区三区在线 | 91精品国产综合久久小美女| 亚洲成人综合在线| 7777精品久久久大香线蕉 | 日本不卡视频在线| 欧美精品色综合| 麻豆国产一区二区| 久久精品亚洲国产奇米99| 国产高清不卡一区| 亚洲色图视频网站| 欧美日韩一级片在线观看| 日韩精品成人一区二区三区 | 亚洲一区二区三区四区不卡| 色婷婷久久99综合精品jk白丝| 亚洲欧美另类图片小说| 欧美日韩国产首页在线观看| 免费成人深夜小野草| 欧美精品一区二区三区蜜桃视频| 国产**成人网毛片九色| 亚洲免费看黄网站| 欧美一级专区免费大片| 国产在线精品一区二区三区不卡 | 精品久久久久香蕉网| 国产一区二区视频在线| 最新热久久免费视频| 欧美日韩在线一区二区| 韩国成人在线视频| 亚洲人吸女人奶水| 日韩你懂的在线观看| 99亚偷拍自图区亚洲| 日韩精品一级中文字幕精品视频免费观看 | 精品国产乱码久久久久久闺蜜| 成人污污视频在线观看| 欧美一级高清片| 波多野结衣中文字幕一区二区三区| 亚洲精品中文字幕在线观看| 欧美一级片免费看| 99riav久久精品riav| 久久99国产精品免费网站| 一区二区三区在线观看国产| 精品美女在线观看| 在线视频你懂得一区二区三区| 奇米影视一区二区三区小说| 中文字幕亚洲不卡| 日韩一区二区三免费高清| 91美女片黄在线观看91美女| 狠狠网亚洲精品| 日韩激情中文字幕| 亚洲激情校园春色| 久久久久久电影| 91精品国产免费久久综合| 一本一本大道香蕉久在线精品| 狠狠狠色丁香婷婷综合久久五月| 午夜久久久影院| 亚洲欧美日韩小说| 欧美国产精品劲爆| 欧美精品一区二区三区久久久| 欧美日韩和欧美的一区二区| 色婷婷狠狠综合| 91亚洲精品乱码久久久久久蜜桃| 国产精品资源在线看| 日韩高清在线一区| 午夜电影一区二区三区| 亚洲欧美日韩国产综合在线| 欧美激情中文字幕| 国产精品美女久久久久av爽李琼 | 99在线精品一区二区三区| 极品少妇xxxx精品少妇| 亚洲二区在线视频| 一区二区三区在线视频免费观看| 成人精品亚洲人成在线| 日本一区二区三级电影在线观看| 日韩高清在线观看| 精品乱码亚洲一区二区不卡| 国产在线国偷精品免费看| 国产精品久久久久永久免费观看 | 图片区小说区国产精品视频| 在线精品视频一区二区三四| 亚洲www啪成人一区二区麻豆| 欧美一级一级性生活免费录像| 99精品欧美一区| 成人精品国产福利| 国产精品久久久久久久久免费桃花| 色婷婷香蕉在线一区二区| 秋霞成人午夜伦在线观看| 亚洲一二三区视频在线观看| 欧美一区二区三区四区高清| 色综合久久久久| 91成人看片片| 国产九色精品成人porny| 国产午夜亚洲精品午夜鲁丝片| 91成人在线精品| 色综合久久久网| 成人自拍视频在线| 国产亚洲一区字幕| 国产成人丝袜美腿| 777久久久精品| 欧美人伦禁忌dvd放荡欲情| 欧日韩精品视频| 欧美日韩二区三区| 日韩精品在线一区二区|