最近两天在学习MongoDB,强大的文档数据库。给我最大的感觉就是相比于SQL或者MSQ等传统的关系型数据库,在使用和配置上真的是简化了很多。无论是在集群的配置还是故障转移方面,都省去了许多繁琐的步骤,但最重要是的什么呢?是效率,它的出现解决了传统关系型数据库的IO瓶颈,极大的提高了工作效率,适合海量数据的查询。

当然,这些老生常谈的话可能你已经听了很多,耳朵都磨出了茧子,废话少说,整点干货。

博客园里关于MongoDB的文章搜一下会出来很多,但是大多都是关于如果安装或者复制集、故障转移等,对于已经学会安装但是希望使用的同学会觉得无从下手,博主感同身受,所以在这里分享一下在.NET中如何使用MongoDB来进行基本的CURD,同时自己写了一个基本的通用帮助类,如果觉得有需要的同学可以拿去使用,觉得有用的可以给个赞,真的,给赞比给钱让我更加欢乐!!!

1.两种常用的操作介质

在.NET中对MongoDB常用的操作介质有两种,分别是BsonDocument对象模型以及自定义的实体类型。

(1)BsonDocument

MongoDB是文档型数据库,在MongoDB的Collection中,每个文档可以看做是一个Bson(Binary Json)对象,所以在驱动中有一个BsonDocument类型,它的本质name/value的键值对集合,可以通过下面方式生成一个BsonDocument的文档,并通过Add方法添加键值对,通过这种方式生成的BsonDocumen对象可以直接插入Collection。

BsonDocument student1 = new BsonDocument();
student1.Add("sid", );
student1.Add("name", "Will10");
student1.Add("gender", "Male");
student1.Add("age", );

(2)自定义实体类型

关于自定义实体类型可能我们每天都在使用,没有什么需要将的,只有一点,如果你想通过自定义的实体类型操作MongoDB中的数据集合,那么你的实体中的字段名要与MongoDB中的字段名保持一致(如_id与ID这样就不一致,则会报错),而且还需要有_id字段。

上面两种方式都可以使用,而且各有好处,通过自定义类型的方式,可以使得collection中的文档有比较统一的模式;使用BsonDocument方式则可以支持更多的文档模式,也就是说如果一个collection中的文档拥有各种各样的模式,那么BsonDocument方式就会更灵活。

2.连接数据库

供.NET使用的的MongoDB驱动不止一个,官方也有推荐的驱动,这里博主选用的是官方推荐的驱动mongocsharpdriver,可以通过NuGet下载安装。

数据库的连接代码如下:

public static void GetColloection(string IP, string Port, string Database, string CollectionName)
{
string connection = string.Format("mongodb://{0}:{1}", Database, Port);
MongoClient client = new MongoClient(connection)
var server = client.GetServer();
collection = server.GetDatabase(Database).GetCollection(CollectionName);
}

这里博主自己封装了一个连接方法,这个连接方法并不好,不够灵活,切换数据集合的时候还要重新输入一遍IP和Port,大家可以自己封装适合自己使用的。

3.查询

(1)查询集合中所有的数据,并返回List集合:

public static List<T> GetList<T>()
{
return collection.FindAllAs<T>().ToList();
}

(2)根据Id查询集合中对应的数据,返回数据实体:(你的VS中需要有对应的实体model)

public static T GetById<T>(int Id)
{
var query = Query.EQ("_id", Id);
return collection.FindOneAs<T>(query);
}

这里使用了Query Builder的查询方式,相比QueryDocument(这里没有使用)这是一种更简洁的查询方式,EQ的意思表示“==”,其它还有GT(>)等。当通过这种方式查询的时候,我们需要使用driver中的builder来生成query。所以,要引用下面using语句:

using MongoDB.Driver.Builders;

通过下面的语句,可以查询年龄大于20的学生:

 var query = Query.GT("age", );
foreach (var student in collection.Find(query))
{
Console.WriteLine(student);
}

(3)根据字段查询对应的数据实体

很多时候我们会根据Id查询数据,但是有些情况下我们可能会用到其它的数据来查询,这里封装了一个方法:

public static List<T> GetValueByKey<T>(string key, string value)
{
var query = Query.EQ(key, value);
return collection.FindAs<T>(query).ToList();
}

(4)Linq查询

在driver的1.8 release之后,官方驱动就可以支持LINQ操作了。我们只需要通过下面的using语句,就可以支持LINQ的方式进行查询了。

using MongoDB.Driver.Linq;

所以,可以查询年龄大于20的学生,也可以通过下面方式实现:

var linquery = from e in collection.AsQueryable<Student>()
where e.age >
select e; var linquery1 = collection.AsQueryable<Student>().Where(e => e.age > );

4.新增

(1)常用的有Insert方法,它有5个重载,可以根据实际情况选取使用,这里使用它的泛型方法Insert<T>(T document):

public static void Insert<T>(T model)
{
try
{
collection.Insert(model);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}

(2)新增实体集合

public static void Insert<T>(List<T> list)
{
try
{
foreach (var model in list)
{
collection.Insert(model);
} }
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}

5.修改

修改的方式有两种,分别是Save和Update,这里没有进行方法封装,给出示例。

(1)Save

static void Save(MongoCollection collection)
{
var query = Query.EQ("_id", );
var model = collection.FindOneAs<goods>(query);
if (model != null)
{
model.title = "修改测试";
collection.Save(model);
}
}

(2)Update

static void Update(MongoCollection collection)
{
var query = Query.EQ("_id", );
var update = Update<goods>.Set(x=>x.title, "Update修改测试");
collection.Update(query, update);
}

6.删除

删除就比较简单了,给出示例和封装的方法:

(1)示例

static void Remove(MongoCollection collection)
{
var query = Query.EQ("_id", );
collection.Remove(query);
}

(2)封装的方法

public static void Remove(IMongoQuery query)
{
try
{
collection.Remove(query);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}

好了,基本CURD到这里就完成了,希望前面讲的东西能够帮助到你,说实话,MongoDB真的很强大,但是呢,刚开始学习肯定会有一个懵逼的过程,博主现在还处于懵逼的过程,一边分享一边帮自己梳理。下一篇MongoDB会写一下复制集以及分片,但不会写怎么操作,毕竟园子里一搜一大把(主要是博主自己学的也不咋样),会写一下在使用的过程中的出错点以及其中的原理,比如Master宕掉以后是如何从Slave中选举出一个新的Master以及Slave的种类和作用。

 

MongoDB 基础教程CURD帮助类的更多相关文章

  1. MongoDB基础教程系列--未完待续

    最近对 MongoDB 产生兴趣,在网上找的大部分都是 2.X 版本,由于 2.X 与 3.X 差别还是很大的,所以自己参考官网,写了本系列.MongoDB 的知识还是很多的,本系列会持续更新,本文作 ...

  2. MongoDB基础教程系列--目录结构

    最近对 MongoDB 产生兴趣,在网上找的大部分都是 2.X 版本,由于 2.X 与 3.X 差别还是很大的,所以自己参考官网,写了本系列.MongoDB 的知识还是很多的,本系列会持续更新,本文作 ...

  3. MongoDB基础教程[菜鸟教程整理]

    MongoDB基础教程 ======================================================================================== ...

  4. Java基础教程(19)--Object类

      Object类位于类结构树的最顶端,所有的类都是它的直接或间接子类,因此所有的类都继承了Object类的方法,我们可以在需要的时候覆盖这些方法.下面是一些将会在本文中讨论的Object类的方法: ...

  5. MongoDB基础教程(安装、操作、配置)

    MongoDB 下载安装 简易安装 # redhat, centOS sudo yum install -y mongodb # debian, ubuntu sudo apt install -y ...

  6. MongoDB基础教程系列--第一篇 进入MongoDB世界

    1.什么是MongoDB MongoDB是跨平台的.一个基于分布式文件存储的数据库.由C++语言编写.用它创建的数据库具备性能高.可用性强.易于扩展等特点.MongoDB将数据存储为一个文档,数据结构 ...

  7. MongoDB基础教程系列--第二篇 MongoDB基本操作(一)

    1.安装环境 在官网上下载MongoDB的最新版本,根据自身Windows版本下载正确的MongoDB版本.下载后,双击32位或者64位.msi文件,按操作提示安装就可以了. 说明: 32 位版本的 ...

  8. MongoDB基础教程系列--第三篇 MongoDB基本操作(二)

    1.集合操作 1.1.创建集合 MongoDB 用 db.createCollection(name, options) 方法创建集合. 格式 db.createCollection(name, op ...

  9. MongoDB基础教程系列--第四篇 MongoDB 查询文档

    查询文档 查询文档可以用 find() 方法查询全部文档,可以用 findOne() 查询第一个文档,当然还可以根据 条件操作符 和 $type操作符 查询满足条件的文档. find() 和 find ...

随机推荐

  1. Netty源码分析 (一)----- NioEventLoopGroup

    提到Netty首当其冲被提起的肯定是支持它承受高并发的线程模型,说到线程模型就不得不提到NioEventLoopGroup这个线程池,接下来进入正题. 线程模型 首先来看一段Netty的使用示例 pa ...

  2. 浅谈JavaWeb发展

    真的认认真真了解JavaWeb的发展,还是因为突然帮朋友弄个没什么功能的小网站时的突然奇想.但是上来就搭SSM的框架,搭到一半却想起来没什么功能那么麻烦干嘛.干脆不用框架,可是又蒙了,不用框架怎么写. ...

  3. .NET Core CSharp 中级篇2-8 特性标签

    .NET Core CSharp 中级篇2-8 本节内容为特性标签 简介 标签Attribute是一个非常重要的技术,你可以使用Attribute技术优化精简你的代码.特性标签可以运用在程序集,模块, ...

  4. 你知道@RequestMapping的name属性有什么用吗?【享学Spring MVC】

    每篇一句 牛逼架构师:把复杂问题简单化,把简单问题搞没 菜逼架构师:把简单问题复杂化 前言 不知这个标题能否勾起你的好奇心和求知欲?在Spring MVC的使用中,若我说@RequestMapping ...

  5. Elasticsearch 顶尖高手(1)

    1.什么是搜索? 百度 = 搜索,这是不对的 垂直搜索(站内搜索) 互联网的搜索:电商网站,招聘网站,新闻网站,各种app IT系统的搜索:OA软件,办公自动化软件,会议管理,项目管理,员工管理 搜索 ...

  6. 【LeetCode】79-单词搜索

    题目描述 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中 "相邻" 单元格是那些水平相邻或垂直相邻的单元格.同一 ...

  7. javase复习(一)

    break,continue,return区别: continue:跳出本次循环,还要再执行下次循环 break:跳出循环,若有多层循环则只跳出本层循环,其他层的循环需要挨个break return: ...

  8. SAP压缩excel并发送mail案例

    "SAP压缩附件 REPORT ZMMR0033_DEL7 . TYPES: BEGIN OF bin_file,            name TYPE string,          ...

  9. JAVA面试问题与解答(1-15)

    Q1.内部类和子类之间有什么区别? Ans:Inner类是嵌套在另一个类中的类.内类具有嵌套它的类的访问权限,并且它可以访问外部类中定义的所有变量和方法. 子类是从另一个名为super class的类 ...

  10. [Pandas] 05 - Parallel processing

    相关资源 [Python] 09 - Multi-processing [Pandas] 01 - A guy based on NumPy [AI] 深度数学 - Bayes 这章非常有意思,但一定 ...