mongodb c# driver(驱动)介绍

目前基于C#的mongodb驱动有两种,分别是官方驱动(下载地址)和samus驱动(下载地址)。
本次我们只演示官方驱动的使用方法。
官方驱动文档查看

第一步:引用驱动dll

引用驱动有两种方式:
1. 根据上面的下载地址下载对应的版本,然后引用到项目中。
2. 在项目的引用上右击->管理NuGet程序包(首先确保安装了nuget扩展包)->联机搜索官方驱动dll(搜索条件是 “Official MongoDB”)->安装成功后会引用3个dll(MongoDB.Driver和MongoDB.Bson,Newtonsoft.Json)。

第二步:构造MongodbHelper类

代码如下:

using MongoDB.Driver;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace Server.DAL.DBHelper
{
public sealed class MongodbHelper
{
static public readonly MongodbHelper Instance = new MongodbHelper();
private MongoDatabase db; private MongodbHelper()
{
//http://www.studyofnet.com/news/337.html
//mongodb://[username:password@]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]]
string strconn = "mongodb://sa:123456@127.0.0.1:27017";
string dbName = "test";
MongoDB.Driver.MongoClient mongoClient = new MongoClient(strconn);
MongoServer server = mongoClient.GetServer();
db = server.GetDatabase(dbName);
} public MongoDatabase DB
{
get { return db; }
} public MongoCollection this[string value]
{
get
{
return db.GetCollection(value);
}
} }
}

第三步:添加实体对象

在此建立的是一个复杂person对象,如下代码:

 public class Test:BaseEntity
{
}
public class PersonType : BaseEntity
{
public string Code { get; set; }
public string Display { get; set; }
}
public class Person : BaseEntity
{
//如果对应多个分类,则格式为:,3,34,2
public string PersonType { get; set; }
public string Name { get; set; }
public bool Sex { get; set; }
public int Age { get; set; }
//默认是国际时间
[MongoDB.Bson.Serialization.Attributes.BsonDateTimeOptions(Kind = DateTimeKind.Local)]
public DateTime AddTime { get; set; }
public List<Address> Addresses { get; set; }
public List<string> Courses { get; set; }
} public class Address
{
public string Province { get; set; }
public string City { get; set; }
}

BaseEntity说明

BaseEntity中放的是mongodb数据库中自动生成的_id(类型是ObjectId)

 public class BaseEntity
{
/// <summary>
/// 字段映射,告诉mongodb这个字段在数据库中对应_id
/// </summary>
[BsonId]
//告诉mongodb这个字段在数据库中的类型是ObjectId
[BsonRepresentation(BsonType.ObjectId)]
public string _id { get; set; }
}

第四步:创建ApiController

创建ApiController基类BaseApiController

BaseApiController中会初始化一些变量,代码如下:

 public class BaseApiController : ApiController
{
public int skip, take;
public MongoDatabase db;
public MongoCollection col = null;//用于直接返回查询的json
public BaseApiController(string collectionName)
{
skip = GetIntRequest("skip");
take = GetIntRequest("take");
if (skip == && take == )
{
take = int.MaxValue;
} db = Server.DAL.DBHelper.MongodbHelper.Instance.DB;
col = db.GetCollection(collectionName);
}
public string GetStringRequest(string paramter)
{
return HttpContext.Current.Request.QueryString[paramter] ?? "";
}
public int GetIntRequest(string paramter)
{
string tmp = HttpContext.Current.Request.QueryString[paramter] ?? "";
int tag = ;
int.TryParse(tmp, out tag);
return tag;
}
}

创建TestController继承BaseApiController

我们就用TestController来演示CURD.
具体代码如下,不再做详细说明:

public class TestController : Filter.BaseApiController
{
public TestController()
: base("Person")
{
} public string Post([FromBody]object value)
{
var model = JsonConvert.DeserializeObject<Person>(value.ToString());
model._id = ObjectId.GenerateNewId().ToString();
try
{
col.Insert(model);
return model._id;
}
catch (WebException ex)
{
throw ex;
}
}
public object Get()
{
try
{
IEnumerable<Person> queryable = col.AsQueryable<Person>();
Func<Person, bool> where = null; //有多少条件并多少条件 //like
//var name = GetStringRequest("Name");
if (!string.IsNullOrEmpty(name))
{
where = c => c.Name.Contains(name);
queryable = queryable.Where(where);
}
//单个条件等值查询
var personType = GetStringRequest("personType");
if (!string.IsNullOrEmpty(personType))
{
where = c => c.PersonType == personType;
queryable = queryable.Where(where);
}
//嵌套数组查询
var course = GetStringRequest("course");
if (!string.IsNullOrEmpty(course))
{
where = c => c.Courses.Contains(course);
queryable = queryable.Where(where); }
//嵌套实体集合查询---查数量
var address = GetStringRequest("address");
if (!string.IsNullOrEmpty(address))
{
where = c => c.Addresses.Count > GetIntRequest("address");
queryable = queryable.Where(where); }
var personList = queryable.OrderByDescending(c => c._id).Skip(skip).Take(take).ToList();
var count = queryable.Count(); var data = new { count = count, dataList = personList };
return data;
}
catch (WebException ex)
{
throw ex;
}
} public Person Get(string id)
{
try
{
var model = col.AsQueryable<Person>().FirstOrDefault(c => c._id == id);
return model;
}
catch (WebException ex)
{ throw ex;
}
} //部分字段修改模式,只修改需要修改的字段。缺点是只能修改单个属性,对于嵌套数组和嵌套实体集合无法修改
public int Put(string id, [FromBody]object value)
{
try
{
var query = new QueryDocument { { "_id", ObjectId.Parse(id) } };
var dicData = JsonConvert.DeserializeObject<Dictionary<string, object>>(value.ToString());
var update = new UpdateDocument { { "$set", new QueryDocument(dicData) } };
col.Update(query, update);
return ;
}
catch (WebException ex)
{
throw ex;
} } //完全修改模式,先查后改,支持任意类型的对象的修改。缺点是需要先查询一次
public int Put([FromBody]object value)
{
try
{
var model = JsonConvert.DeserializeObject<Person>(value.ToString());
col.Save(model);
return ;
}
catch (WebException ex)
{ throw ex;
} }
public void Delete(string id)
{
try
{
var query = new QueryDocument { { "_id", ObjectId.Parse(id) } };
col.Remove(query);
}
catch (WebException ex)
{ throw ex;
}
}
}

第五步:CURD演示

在这里我们使用一个工具Fiddler2演示。

添加

Mongodb学习笔记五(C#操作mongodb)的更多相关文章

  1. MongoDB学习笔记二—Shell操作

    数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ...

  2. Python学习笔记_03:简单操作MongoDB数据库

    目录 1. 插入文档 2. 查询文档 3. 更新文档 4. 删除文档   1. 插入文档 # -*- coding: UTF-8 -*- import datetime from pymongo im ...

  3. MongoDB学习笔记—Linux下搭建MongoDB环境

    1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...

  4. MongoDB 学习笔记(三) MongoDB (replica set) 集群配置

    MongoDB Replica Sets的结构类似于以集群,完全可以把他当成一个集群,因为他确实与集群实现的作用是一样的:如果其中一个节点出现故障,其他的节点会马上将业务接管过来.而无需停机操作 Mo ...

  5. MongoDB 学习笔记四 C#调用MongoDB

    驱动 下载 https://github.com/mongodb/mongo-csharp-driver/downloads 项目地址: https://github.com/mongodb/mong ...

  6. MongoDB学习笔记(四、MongoDB安全管理)

    目录: mongoDB角色 mongoDB初始化账号 mongoDB安全认证 其它常用的命令 mongoDB角色: mongoDB初始化账号: 1.启动mongoDB ./mongod -f mong ...

  7. MongoDB学习笔记(五) MongoDB文件存取操作

    由于MongoDB的文档结构为BJSON格式(BJSON全称:Binary JSON),而BJSON格式本身就支持保存二进制格式的数据,因此可以把文件的二进制格式的数据直接保存到MongoDB的文档结 ...

  8. MongoDB学习笔记五:聚合

    『count』count是最简单的聚合工具,返回集合中的文档数量:> db.foo.count()0> db.foo.insert({"x" : 1})> db. ...

  9. MongoDB学习笔记——文档操作之查询

    查询文档 使用db.COLLECTION_NAME.findOne()可以查询所有满足条件的第一条数据 预发格式如下: db.COLLECTION_NAME.findOne(<query> ...

随机推荐

  1. Jq基础简介

    jQuery就是用原生js写出的框架集(Write less do more ) 1.需要注意的问题?(1).jQuery语法需要重新学习(2).jQuery需要注意版本之间的兼容性 (3)不是越新的 ...

  2. Linux vi/vim(转载)

    Linux vi/vim 所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在. 但是目前我们使用比较多的是 vim 编辑器. vim 具有程序编辑的能力,可以主 ...

  3. C# partial 學習筆記

    局部類的講解參考:http://blog.csdn.net/susan19890313/article/details/7575204 感謝作者~

  4. 深入浅出React Native 1: 环境配置

    该教程主要介绍如何用react native来开发iOS,所以首先,你需要有一台mac,当然黑苹果也是可以的~ 创建一个react native的项目只需要安装以下五个组件~~(但....坑爹的是,不 ...

  5. CSS3-05 样式 4

    前言 关于 CSS 的介绍,基本上告一段落了.在该博客中将介绍如何通过 CSS 去设置一个 HTML 元素,显示在 Web 页面的位置. 定位 概述 定义元素位置的基准,即:该元素与 HTML 文档流 ...

  6. ios手势操作,四个基本事件与六个常用事件

    基本事件包括begin,canceled,move,ended四项,如果对象的hidden属性为yes,则无效果,hidden属性必须为no;才能使用: -(void)touchesBegan:(NS ...

  7. 微软源代码管理工具TFS2013安装与使用详细图文教程(Vs2013)

    这篇文章联合软件小编主要介绍了微软源代码管理工具TFS2013安装与使用图文教程,本文详细的给出了TFS2013的安装配置过程.使用教程,需要的朋友可以参考下 最近公司新开发一个项目要用微软的TFS2 ...

  8. JavaScript(js)的replace问题的解决

    我是前端的门外汉,js我用得比较少.今天意外发现js自带的replace “居然”只替换1处,而其它的许多许多语言都是替换全部的. 你可能会说,切,我早就知道.高手请绕道. 你可能会说,用js的正则就 ...

  9. DDD实施经验分享—价值导向、从上往下进行(圈内第一个吃螃蟹DDD实施方案)

    阅读目录: 1.背景 2.从业务开始 3.从战略到战术 4.借助外力推动研发(QA.领导.自动化测试) 5.领域模型与SAAS平台的内核(价值最大化) 6.最后 1.背景 DDD本身的技术就不介绍了, ...

  10. ASP.NET MVC Razor

    Razor是MVC3中才有的新的视图引擎.我们知道,在ASP.NET中,ASPX的视图引擎依靠<%和%>来调用C#指令.而MVC3以后有了一套新的使用@标记的Razor语法,使用起来更灵活 ...