偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

說(shuō)說(shuō)MongoDB的插入原理

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù) MongoDB
MongoDB插入原理:使用驅(qū)動(dòng)程序進(jìn)行插入的時(shí)候,會(huì)將數(shù)據(jù)轉(zhuǎn)換成BSON格式。數(shù)據(jù)庫(kù)會(huì)解析BSON,并檢驗(yàn)是否含有“_id”鍵,因?yàn)椤癬id”鍵在插入到數(shù)據(jù)庫(kù)時(shí)MongoDB會(huì)自動(dòng)生成。而且每次插入文檔不能超過(guò)4M。這個(gè)應(yīng)該是和MongoDB本身有關(guān)。

在開(kāi)發(fā)之前,選擇MongoDB驅(qū)動(dòng)是件很重要的事情。如果選擇不好,在后期的開(kāi)發(fā)的是件很費(fèi)力的事情,因?yàn)槲揖陀龅竭@樣的問(wèn)題。MongoDB驅(qū)動(dòng)有幾種比較流行驅(qū)動(dòng),官方驅(qū)動(dòng)和samus是兩種使用比較多的。

好了,接著說(shuō)今天的內(nèi)容了。

首先從MongoDB的官方網(wǎng)站上下載CSharp驅(qū)動(dòng)(https://github.com/mongodb/mongo-csharp-driver/downloads)。我使用的是CSharpDriver-1.1.0.4184,里面還包含一個(gè)CSharpDriverDocs.chm的文檔。

MongoDB插入原理:使用驅(qū)動(dòng)程序進(jìn)行插入的時(shí)候,會(huì)將數(shù)據(jù)轉(zhuǎn)換成BSON格式。數(shù)據(jù)庫(kù)會(huì)解析BSON,并檢驗(yàn)是否含有“_id”鍵,因?yàn)?ldquo;_id”鍵在插入到數(shù)據(jù)庫(kù)時(shí)MongoDB會(huì)自動(dòng)生成。而且每次插入文檔不能超過(guò)4M。這個(gè)應(yīng)該是和MongoDB本身有關(guān)。但是MongoDB1.8版本的支持16M,為什么是這個(gè)樣子我到?jīng)]怎么研究。這個(gè)想留給有心人幫忙解決下了。

插入的Shell操作有Insert和Save兩種語(yǔ)法,先看下面的Shell

  1. > var time = new Date("2011/8/28 21:50:00"//定義一個(gè)時(shí)間對(duì)象 
  2. > var i = {"time":time,"userid":10001,"sessionid":"20110829215100","ip":"192.168.0.1","title":"Login","url":"Login.aspx"}  //定義一個(gè)文檔對(duì)象 
  3. > i   //查看 i 文檔 
  4.         "time" : ISODate("2011-08-28T13:50:00Z"), 
  5.         "userid" : 10001, 
  6.         "sessionid" : "20110829215100"
  7.         "ip" : "192.168.0.1"
  8.         "title" : "Login"
  9.         "url" : "Login.aspx" 
  10. > use testDb 
  11. > show collections  //查看當(dāng)前集合,把i文檔插入到login集合中 
  12. myc 
  13. myc1 
  14. myc2 
  15. system.indexes 
  16. > db.login.insert(i) 
  17. > db.login.findOne() 
  18.         "_id" : ObjectId("4e5b99e62690d28cadd0f58d"), //MongoDb會(huì)為每個(gè)插入的對(duì)象自動(dòng)生成一個(gè)"_id"的值,你可以在插入的時(shí)候自己指定這個(gè)值,如下面 
  19.         "time" : ISODate("2011-08-28T13:50:00Z"), 
  20.         "userid" : 10001, 
  21.         "sessionid" : "20110829215100"
  22.         "ip" : "192.168.0.1"
  23.         "title" : "Login"
  24.         "url" : "Login.aspx" 
  25. > i = {"_id":"newid_100001","time":time,"userid":10001,"sessionid":"20110829215100","ip":"192.168.0.1","title":"Login","url":"Login.aspx"
  26.         "_id" : "newid_100001"
  27.         "time" : ISODate("2011-08-28T13:50:00Z"), 
  28.         "userid" : 10001, 
  29.         "sessionid" : "20110829215100"
  30.         "ip" : "192.168.0.1"
  31.         "title" : "Login"
  32.         "url" : "Login.aspx" 
  33. > db.login.save(i) //這里用save插入文檔到數(shù)據(jù)庫(kù) 
  34. > db.login.find()  //查詢結(jié)果兩條文檔,第二條文檔"_id"是自定義的值 
  35. "_id" : ObjectId("4e5b99e62690d28cadd0f58d"), "time" : ISODate("2011-08-28T13:50:00Z"), "userid" : 10001, "sessionid" : "20110829215100"
  36. "ip" : "192.168.0.1""title" : "Login""url" : "Login.aspx" } 
  37. "_id" : "newid_100001""time" : ISODate("2011-08-28T13:50:00Z"), "userid" : 10001, "sessionid" : "20110829215100""ip" : "192.168.0.1"
  38. "title" : "Login""url" : "Login.aspx" } 

注意:

1:Insert和Save的區(qū)別是:如果插入的集合的“_id”值,在集合中已經(jīng)存在,用Insert執(zhí)行插入操作回報(bào)異常,已經(jīng)存在"_id"的鍵。用Save如果系統(tǒng)中沒(méi)有相同的"_id"就執(zhí)行插入操作,有的話就執(zhí)行覆蓋掉原來(lái)的值。相當(dāng)于修改操作。我這里就不做演示了。

下面說(shuō)下用C#驅(qū)動(dòng) 添加文檔。

2:在新建一個(gè)集合或者一個(gè)數(shù)據(jù)庫(kù)時(shí),MongoDb不會(huì)在馬上生成。而是在你添加了第一個(gè)數(shù)據(jù)后才會(huì)有顯示。這個(gè)特性很多的數(shù)據(jù)庫(kù)都用,比如說(shuō)SQLite。

下面說(shuō)下用 C#驅(qū)動(dòng) 添加文檔

  1. #region Version Info 
  2. /* ========================================================================  
  3.     * 【說(shuō)明描述】  
  4.     *   
  5.     * 作者:yoolo        時(shí)間:2011/8/29 21:15:38  
  6.     * 文件名:NoSpiderAuto.LoginDemo 
  7.     * 版本:V1.0.1  
  8.     *  
  9.     * 修改者:           時(shí)間:                
  10.     * 修改說(shuō)明:  
  11.     * ========================================================================  
  12.   */ 
  13. #endregion 
  14.  
  15. namespace NoSpiderAuto 
  16.     using System; 
  17.     using System.Collections.Generic; 
  18.     using System.Linq; 
  19.     using System.Text; 
  20.     using MongoDB.Driver; 
  21.     using MongoDB.Bson; 
  22.  
  23.     internal class LoginDemo 
  24.     { 
  25.         MongoDatabase db; 
  26.         MongoCollection coll; 
  27.         public LoginDemo() 
  28.         { 
  29.             MongoServerSettings set = new MongoServerSettings() 
  30.             { 
  31.                 Server = new MongoServerAddress("127.0.0.1"
  32.             }; 
  33.             MongoServer server = new MongoServer(set); 
  34.             db = server.GetDatabase("testDb"); 
  35.             coll = db.GetCollection("login"); 
  36.         } 
  37.  
  38.         /// <summary> 
  39.         /// 單個(gè)對(duì)象插入 
  40.         /// </summary> 
  41.         public void InsertLogin() 
  42.         { 
  43.             var Time = DateTime.Now.ToUniversalTime(); 
  44.  
  45.             //實(shí)例一 添加匿名對(duì)象 
  46.             var login = new { _id = "newid_100002", time = Time, userid = 10002, sessionid = "20110829215102", ip = "192.168.0.2", title = "注冊(cè)", url = "Register.aspx" }; 
  47.             coll.Insert(login);//插入成功 
  48.  
  49.             //添加一個(gè)BsonDocument對(duì)象 
  50.             BsonDocument doc = new BsonDocument(); 
  51.             doc.Add("_id", BsonValue.Create("newid_100003")); 
  52.             doc.Add("time", BsonValue.Create(Time)); 
  53.             doc.Add("userid", BsonValue.Create(10003)); 
  54.             doc.Add("sessionid", BsonValue.Create("20110829215103")); 
  55.             doc.Add("ip", BsonValue.Create("192.168.0.3")); 
  56.             doc.Add("title", BsonValue.Create("注冊(cè)")); 
  57.             doc.Add("url", BsonValue.Create("Register.aspx")); 
  58.             coll.Insert(doc);//插入成功 
  59.  
  60.             //添加一個(gè)對(duì)象 
  61.             Login man = new Login(); 
  62.             man._id = "newid_100004"
  63.             man.time = Time; 
  64.             man.userid = 10004; 
  65.             man.sessionid = "20110829215104"
  66.             man.ip = "192.168.0.4"
  67.             man.title = "注冊(cè)"
  68.             man.url = "Register.aspx"
  69.             coll.Insert(man);//插入成功 
  70.  
  71.         } 
  72.         /// <summary> 
  73.         /// 批量插入 
  74.         /// </summary> 
  75.         public void InsertBatchLogin() 
  76.         { 
  77.             var Time = DateTime.Now.ToUniversalTime(); 
  78.             List<Login> logins = new List<Login>(); 
  79.  
  80.             for (int i = 0; i < 100; i++) 
  81.             { 
  82.                 Login man = new Login(); 
  83.                 man._id = "newid_100001" + i.ToString();//_id在批量插入的時(shí)候不能重復(fù),如果有一個(gè)重復(fù)全部集合無(wú)法插入到集合 
  84.                 man.time = Time; 
  85.                 man.userid = 10004 + i; 
  86.                 man.sessionid = "20110829215104"
  87.                 man.ip = "192.168.0.4"
  88.                 man.title = "注冊(cè)"
  89.                 man.url = "Register.aspx"
  90.                 logins.Add(man); 
  91.             } 
  92.             coll.InsertBatch(typeof(Login), logins); //插入成功 
  93.         } 
  94.     } 
  95.  
  96.     public class Login 
  97.     { 
  98.         public string _id { getset; } 
  99.         public DateTime time { getset; } 
  100.         public int userid { getset; } 
  101.         public string sessionid { getset; } 
  102.         public string ip { getset; } 
  103.         public string title { getset; } 
  104.         public string url { getset; } 
  105.     } 

如果要插入多個(gè)文檔,使用批量插入會(huì)快一些。一次批量插入只是單個(gè)Tcp請(qǐng)求,也就是避免了多個(gè)請(qǐng)求帶來(lái)的開(kāi)銷!

原文鏈接:http://www.cnblogs.com/yoolonet/archive/2011/08/29/2158966.html#

【編輯推薦】

  1. MongoDB之父:MongoDB勝過(guò)BigTable
  2. 主流NoSQL數(shù)據(jù)庫(kù)全方位評(píng)測(cè)之MongoDB
  3. 教你如何利用MySQL學(xué)習(xí)MongoDB
  4. 在Windows環(huán)境下MongoDB搭建和簡(jiǎn)單操作
  5. Mongodb源碼分析之Mongos分析

 

 

 

 

 

 

 

責(zé)任編輯:艾婧 來(lái)源: Yoolo的博客
相關(guān)推薦

2011-05-26 13:43:30

MongoDB

2025-04-16 00:00:01

JWT客戶端存儲(chǔ)加密令

2024-11-19 15:13:02

2023-12-27 18:16:39

MVCC隔離級(jí)別幻讀

2024-06-20 08:06:51

2024-07-16 18:05:19

延遲隊(duì)列MQRabbitMQ

2021-07-16 07:57:34

ReduxDOM組件

2024-03-14 14:56:22

反射Java數(shù)據(jù)庫(kù)連接

2024-07-31 08:28:37

DMAIOMMap

2024-12-06 07:00:00

2024-03-11 18:18:58

項(xiàng)目Spring線程池

2024-09-20 08:36:43

零拷貝數(shù)據(jù)傳輸DMA

2024-03-22 06:56:24

零拷貝技術(shù)數(shù)據(jù)傳輸數(shù)據(jù)拷貝

2024-07-05 17:47:21

@Async項(xiàng)目啟動(dòng)類

2024-08-22 10:39:50

@Async注解代理

2024-03-05 10:33:39

AOPSpring編程

2024-06-21 08:02:22

2024-07-17 17:54:28

XXLJob分布式任務(wù)Java

2025-02-28 00:00:00

2024-06-04 09:02:03

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)