说说MongoDB的插入原理

在开发之前,选择MongoDB驱动是件很重要的事情。如果选择不好,在后期的开发的是件很费力的事情,因为我就遇到这样的问题。MongoDB驱动有几种比较流行驱动,官方驱动和samus是两种使用比较多的。

好了,接着说今天的内容了。

首先从MongoDB的官方网站上下载CSharp驱动(https://github.com/mongodb/mongo-csharp-driver/downloads)。我使用的是CSharpDriver-1.1.0.4184,里面还包含一个CSharpDriverDocs.chm的文档。

MongoDB插入原理:使用驱动程序进行插入的时候,会将数据转换成BSON格式。数据库会解析BSON,并检验是否含有“_id”键,因为“_id”键在插入到数据库时MongoDB会自动生成。而且每次插入文档不能超过4M。这个应该是和MongoDB本身有关。但是MongoDB1.8版本的支持16M,为什么是这个样子我到没怎么研究。这个想留给有心人帮忙解决下了。

插入的Shell操作有Insert和Save两种语法,先看下面的Shell

  1. > var time = new Date("2011/8/28 21:50:00"//定义一个时间对象 
  2. > var i = {"time":time,"userid":10001,"sessionid":"20110829215100","ip":"192.168.0.1","title":"Login","url":"Login.aspx"}  //定义一个文档对象 
  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  //查看当前集合,把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会为每个插入的对象自动生成一个"_id"的值,你可以在插入的时候自己指定这个值,如下面 
  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插入文档到数据库 
  34. > db.login.find()  //查询结果两条文档,第二条文档"_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的区别是:如果插入的集合的“_id”值,在集合中已经存在,用Insert执行插入操作回报异常,已经存在”_id”的键。用Save如果系统中没有相同的”_id”就执行插入操作,有的话就执行覆盖掉原来的值。相当于修改操作。我这里就不做演示了。

下面说下用C#驱动 添加文档。

2:在新建一个集合或者一个数据库时,MongoDb不会在马上生成。而是在你添加了第一个数据后才会有显示。这个特性很多的数据库都用,比如说SQLite。

下面说下用 C#驱动 添加文档

  1. #region Version Info 
  2. /* ========================================================================  
  3.     * 【说明描述】  
  4.     *   
  5.     * 作者:yoolo        时间:2011/8/29 21:15:38  
  6.     * 文件名:NoSpiderAuto.LoginDemo 
  7.     * 版本:V1.0.1  
  8.     *  
  9.     * 修改者:           时间:                
  10.     * 修改说明:  
  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.         /// 单个对象插入 
  40.         /// </summary> 
  41.         public void InsertLogin() 
  42.         { 
  43.             var Time = DateTime.Now.ToUniversalTime(); 
  44.  
  45.             //实例一 添加匿名对象 
  46.             var login = new { _id = "newid_100002", time = Time, userid = 10002, sessionid = "20110829215102", ip = "192.168.0.2", title = "注册", url = "Register.aspx" }; 
  47.             coll.Insert(login);//插入成功 
  48.  
  49.             //添加一个BsonDocument对象 
  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("注册")); 
  57.             doc.Add("url", BsonValue.Create("Register.aspx")); 
  58.             coll.Insert(doc);//插入成功 
  59.  
  60.             //添加一个对象 
  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 = "注册"
  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在批量插入的时候不能重复,如果有一个重复全部集合无法插入到集合 
  84.                 man.time = Time; 
  85.                 man.userid = 10004 + i; 
  86.                 man.sessionid = "20110829215104"
  87.                 man.ip = "192.168.0.4"
  88.                 man.title = "注册"
  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.     } 

如果要插入多个文档,使用批量插入会快一些。一次批量插入只是单个Tcp请求,也就是避免了多个请求带来的开销!

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

【编辑推荐】

  1. MongoDB之父:MongoDB胜过BigTable
  2. 主流NoSQL数据库全方位评测之MongoDB
  3. 教你如何利用MySQL学习MongoDB
  4. 在Windows环境下MongoDB搭建和简单操作
  5. Mongodb源码分析之Mongos分析

 

 

 

 

 

 

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/294795.html<

(0)
运维的头像运维
上一篇2025-05-21 06:08
下一篇 2025-05-21 06:09

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注