国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

c# 插入數(shù)據(jù)效率測試(mongodb)

2019-10-29 21:03:09
字體:
供稿:網(wǎng)友

mongodb的數(shù)據(jù)插入速度是其一個亮點,同樣的10000條數(shù)據(jù),插入的速度要比Mysql和sqlserver都要快,當然這也是要看使用者怎么個使用法,你代碼如果10000次寫入使用10000次連接,那也是比不過其他數(shù)據(jù)庫使用事務一次性提交的速度的。

同樣,mongo也提供的一次性插入巨量數(shù)據(jù)的方法,因為mongodb沒有事務這回事,所以在在C#驅(qū)動里,具體方法是InsertManyAsync()一次性插入多個文檔。與之對應的是InsertOneAsync,這個是一次插入一個文檔;

InsertManyAsync()這個方法帶入的參數(shù)只要是實現(xiàn)了IEnumerable接口的類型就可以,所以可是list<>,這樣的數(shù)據(jù)類型;

同樣的10000次插入,兩個方法時間差別很大。如圖:

c#,mongodb,添加數(shù)據(jù)

使用一次性插入多個文檔方法,插入10000條耗時僅1.3秒,分成10000次插入,耗時19.9秒。區(qū)別大了個去。同樣,前面我做過使用mysql插入10000條記錄,要用4秒多,可見,這mongodb插入速度不是吹 的。

具體的代碼如下,貼上:

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using MongoDB.Bson; using MongoDB.Driver; using System.Diagnostics; namespace sqltomongo {   public  class MongoHelp   {     private static IMongoClient client     {       get       {         if (null == _client)         {           _client = new MongoClient("mongodb://127.0.0.1:27017");         }         return _client;       }     }     public  static IMongoDatabase database     {       get {          _database = client.GetDatabase("HotelPersonInfo");          return _database;       }       set {         _database = value;       }     }      public  static IMongoCollection<BsonDocument> collection     {       get {         return _collection;       }       set {         _collection = value;       }     }      protected static IMongoClient _client;     protected static IMongoDatabase _database;     protected static IMongoCollection<BsonDocument> _collection;      //測試效率,兩個方法用時比較     public async static void TestMongo()     {       //自定義的對象       RoomInfo roomdata = new RoomInfo();       List<BsonDocument> docunemts = new List<BsonDocument>();       collection = database.GetCollection<BsonDocument>("HotelPersonInfo");       Stopwatch sw = new Stopwatch();       sw.Start();       for (int i = 1; i < 10000; i++)       {          //mongo對用戶自定義的對象擴展了tobasonDocument這個方法,可直接用         var roomdatadocument = new BsonDocument(roomdata.ToBsonDocument());         docunemts.Add(roomdatadocument);       }       //一次10000條        //這方法 查看api手冊,只要實現(xiàn)了IEnumerable借口的類型就都行       await collection.InsertManyAsync(docunemts);       sw.Stop();        TimeSpan ts2 =sw.Elapsed;        Console.WriteLine("total is " + ts2.TotalMilliseconds);        ///一次次插 10000次        Stopwatch sw2 = new Stopwatch();        sw2.Start();        for (int i = 1; i < 10000; i++)        {          var roomdatadocument = new BsonDocument(roomdata.ToBsonDocument());          await collection.InsertOneAsync(roomdatadocument);        }               sw2.Stop();        TimeSpan ts22 = sw2.Elapsed;        Console.WriteLine("total is " + ts22.TotalMilliseconds);       // await collection.InsertOneAsync(roomdatadocument);              //collection = database.GetCollection<BsonDocument>("HotelPersonInfo");       // collection.InsertOneAsync(roomdatadocument);     }   } } 

里面使用了一個自定義的對象:

代碼如下:

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using MongoDB.Bson; namespace sqltomongo {    public class RoomInfo    {     public RoomInfo()     {      // id = "test";        Name = "nafd"; Moblie = "123456"; EMail = "dd@qq.com"; Tel = "010123"; Fax = "0755-001";       IdentityId = "616112323231"; RegisterType = "tid"; CardNo = "cardno"; Sex = "男"; Birthday = "1999";       Address = "china beijing"; ZipCode = "519000"; RegisterDate = "2015-03-03";       District2 = "District2";       District3 = "District3";       District4 = "District4";     }    // public string id { get; set; }     /// <summary>     /// 名字     /// </summary>     public string Name { get; set; }            /// <summary>     /// 手機號碼     /// </summary>     public string Moblie { get; set; }     /// <summary>     /// 郵箱     /// </summary>     public string EMail {get;set;}     /// <summary>     /// 座機     /// </summary>     public string Tel { get; set; }     /// <summary>     /// 傳真     /// </summary>     public string Fax { get; set; }     /// <summary>     /// 身份證     /// </summary>     public string IdentityId { get; set; }      /// <summary>     /// 使用什么注冊的     /// ID --身份證 (只需要id身份證的信息)     /// </summary>     public string RegisterType { get; set; }       /// <summary>     /// 會員卡號     /// </summary>     public string CardNo { get; set; }     /// <summary>     /// 性別     /// </summary>     public string Sex { get; set; }     /// <summary>     /// 生日     /// </summary>     public string Birthday { get; set; }     /// <summary>     /// 地址     /// </summary>     public string Address { get; set; }     /// <summary>     /// 郵編     /// </summary>     public string ZipCode { get; set; }      public string District2 { get; set; }     public string District3 { get; set; }     public string District4 { get; set; }     /// <summary>     /// 注冊時間      /// </summary>     public string RegisterDate { get; set; }    } }

mongodb的一些小總結(jié)

mongodb的安裝,官網(wǎng)下載想要的版本,可視化工具mongovue(注意不支持mongodb3.0以上的版本)

下載mis安裝,解壓后bin,。。。

1.配置環(huán)境變量,將H:/mongodb/mongodbInstall/bin bin目錄加入環(huán)境變量的path里面
2.bin目錄同級目錄創(chuàng)建data文件夾,data文件夾內(nèi)新建db、log文件夾log文件夾下再創(chuàng)建mongodb.log
3.輸入如下的命令啟動mongodb服務:(定位到bin下面)
H:/mongodb/mongodbInstall/bin>mongod --dbpath H:/mongodb/mongodbInstall/data/db
http://localhost:27017 測試是否連接成功
4.data同級目錄創(chuàng)建mongodb.config 記事本打開mongodb.config
dbpath=H:/mongodb/mongodbInstall/data/db
logpath=H:/mongodb/mongodbInstall/data/log/mongodb.log
5.用管理員身份打開cmd命令行,進入H:/mongodb/mongodbInstall/bin目錄,輸入如下的命令:
mongod --config H:/mongodb/mongodbInstall/mongo.config --install --serviceName "MongoDB"
services.msc可以看到mongodb的服務已經(jīng)啟動

mongodb安裝配置完成后,cmd直接錄入mongo可進入mongo的命令行,show dbs可以看到現(xiàn)有的數(shù)據(jù)庫(我把之前數(shù)據(jù)庫備份的ns文件放入db文件夾內(nèi),show dbs的時候并沒有顯示出來)

然后安裝mongovue(只有mysql可以免費導入到mongodb,因為有sqlserver的對應數(shù)據(jù)庫,,,所以轉(zhuǎn)化通過sqlserver轉(zhuǎn)化為mysql再導入到mongovue)
sqlserver->mysql:mysql中導入向?qū)?》選擇ODBC-》選擇sql server native client 、設(shè)置連接(服務器名(本機127.0.0.1)然后sqlserver用戶名,密碼)下一步-》下一步。。。。結(jié)束。
mysql->mongodb:add 一個數(shù)據(jù)庫-》右鍵RDBMS Import 然后填寫連接。


注:相關(guān)教程知識閱讀請移步到c#教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 桂阳县| 印江| 民权县| 阜城县| 安徽省| 老河口市| 克东县| 游戏| 璧山县| 嘉善县| 当阳市| 平凉市| 青海省| 绵阳市| 安康市| 景宁| 临澧县| 仲巴县| 兴宁市| 广汉市| 津市市| 房山区| 通化县| 峨山| 曲沃县| 张家界市| 大宁县| 晋城| 兴海县| 长春市| 于都县| 青川县| 铜鼓县| 芦溪县| 金门县| 藁城市| 潞城市| 北宁市| 永济市| 肃北| 怀宁县|