1、下载驱动:

如下图:选择c#解决方案,右键,点击 “管理NuGet程序包(N)...”

在弹出的对话框中,输入MongoDB.Driver,进行搜索,然后选择安装。

2、引用命名空间:

using MongoDB.Bson;
using MongoDB.Driver;
using MongoDB.Driver.Core;

3、程序代码

配置文件:

public class iCTRMongodbCache : CacheBase
{
  IMongoCollection<BsonDocument> _collect;

  IMongoDatabase _db;
  string _collectionName = "";
  /// <summary>
  /// 默认搜索列字段名称
  /// </summary>
  string defaultColumn = ConfigurationManager.AppSettings["DefaultColumn"].ToString();

  /// <summary>
  /// 构造函数
  /// </summary>
  /// <param name="collectionName">集合名称,类似关系型数据库中的表名</param>
  public iCTRMongodbCache(string collectionName)
    : base(collectionName)
  {
    _collectionName = collectionName;
    string mongoDB_Host = ConfigurationManager.AppSettings["MongoDB_Host"].ToString();
    string mongoDB_DbName = ConfigurationManager.AppSettings["MongoDB_DbName"].ToString();
    string mongoDB_UserName = ConfigurationManager.AppSettings["MongoDB_UserName"].ToString();
    string mongoDB_Password = ConfigurationManager.AppSettings["MongoDB_Password"].ToString();
    MongoDB.Driver.MongoClient mc = new MongoClient(mongoDB_Host);

    _db = mc.GetDatabase(mongoDB_DbName);
    _collect = _db.GetCollection<BsonDocument>(collectionName);

  }

  public override bool Append(string keyValue, string value)
  {
    if (string.IsNullOrEmpty(value) || value.IndexOf(":") < 0)
     {
      return false;
     }
    Dictionary<string, string> dictR = new Dictionary<string, string>();
    dictR.Add(defaultColumn, keyValue);
    try
    {
      string[] values = value.Split(',');
      foreach (string keyv in values)
      {
        dictR.Add(keyv.Split(':')[0], keyv.Split(':')[1]);
      }
      BsonDocument bd = new BsonDocument();
      bd.AddRange(dictR);
      _collect.InsertOne(bd);
    }
    catch (System.InvalidOperationException ex)
    {
      throw ex;
    }
    return true;
  }

  public override object Get(string keyValue)
  {
    Dictionary<string,object> dict =new Dictionary<string,object>();
    dict.Add(defaultColumn, keyValue);
    var query = new BsonDocument(dict);
    IAsyncCursor<BsonDocument> result = _collect.FindSync(query);

    List<BsonDocument> list = null;
    if (result.MoveNext())
    {
      list = result.Current as List<BsonDocument>;
    }
    return list;
  }

  public override T Get<T>(string keyValue)
  {
    Dictionary<string, object> dict = new Dictionary<string, object>();
    dict.Add(defaultColumn, keyValue);
    var query = new BsonDocument(dict);
    IAsyncCursor<BsonDocument> result = _collect.FindSync(query);
    if (result.MoveNext())
    {
      List<BsonDocument> list = result.Current as List<BsonDocument>;
      if (list != null)
      {
        BsonDocument bd = list[0];
        bd.Remove("_id");
        bd.Remove(defaultColumn);
        JavaScriptSerializer Serializer = new JavaScriptSerializer();
        Serializer.MaxJsonLength = int.MaxValue;
        return Serializer.Deserialize<T>(bd.ToString());
      }
      else
      {
        return default(T);
      }
    }
    else
    {
      return default(T);
    }
  }

  public override void Set(string keyValue, object value, DateTime expiration)
  {
    Dictionary<string, object> dictR = new Dictionary<string, object>();
    dictR.Add(defaultColumn, keyValue);
    try
      {
        BsonDocument bd = value.ToBsonDocument();
        bd.AddRange(dictR);
        _collect.InsertOne(bd);
      }
    catch (System.InvalidOperationException ex)
      {
        throw ex;
      }

    }

  public override void Set<T>(string keyValue, T value)
  {
    Dictionary<string, object> dictR = new Dictionary<string, object>();
    dictR.Add(defaultColumn, keyValue);
    try
      {
        BsonDocument bd = value.ToBsonDocument<T>();
        bd.AddRange(dictR);
        _collect.InsertOne(bd);
      }
    catch (System.InvalidOperationException ex)
    {
      throw ex;
    }
  }

  public override void Remove(string key)
  {
    Dictionary<string, object> dictR = new Dictionary<string, object>();
    dictR.Add(defaultColumn, key);
    _collect.DeleteOne(new BsonDocument(dictR));

  }

  public override void Clear()
  {
    _db.DropCollection(_collectionName);
  }

  public override void Dispose()
  {
    _db.DropCollection(_collectionName);
    _collect = null;
  }
 }

4、测试代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using MongodbCache.Caching;
namespace UnitTest
{
  [TestClass]
  public class iCTRMongodbCacheTest
  {
    private iCTRMongodbCache _cache;
    public iCTRMongodbCacheTest()
    {
    _cache = new iCTRMongodbCache("test1");
  }

  [TestMethod]
  public void TestAppend()
  {
    //ID454为主键字段对应的数据,"age:43,name:Marry为要插入的数据,
    //调用缓存的Append方法,第二个参数必须为类似"column1 : column1Value,column2 : column2Value "的数据
    _cache.Append("ID1", "age:43,name:Marry");
  }

  [TestMethod]
  public void TestSet1()
  {
    Dictionary<string, string> dict = new Dictionary<string, string>();
    dict.Add("age", "12");
    dict.Add("Name", "Marry");
    _cache.Set("ID2", dict);
  }
  [TestMethod]
  public void TestSet2()
  {
    student s = new student();
    s.age = 234;
    s.name = "lengli";
    _cache.Set<student>("ID3", s);
  }

  [TestMethod]
  public void TestRemove()
  {
    string ID = "ID1";
    _cache.Remove(ID);
  }

  [TestMethod]
  public void TestGet1()
  {
    object obj = _cache.Get("ID2");
  }

  [TestMethod]
  public void TestGet2()
  {
    student dd = _cache.Get<student>("ID3");
  }

  [TestMethod]
  public void TestClear()
  {
    _cache.Clear();
  }

  [TestClass]
  class student
  {
    public string name
    {
      get;
      set;
    }

    public int age
    {
      get;
      set;
    }

  }
  }
}

C#操作mongodb数据库的更多相关文章

  1. 不使用spring的情况下原生java代码两种方式操作mongodb数据库

    由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常.   主要原因实际上是和mongodb本身无关的,因为他们改的是配置 ...

  2. 不使用spring的情况下用java原生代码操作mongodb数据库的两种方式

    由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常.   主要原因实际上是和mongodb本身无关的,因为他们改的是配置 ...

  3. NodeJs连接操作MongoDB数据库

    NodeJs连接操作MongoDB数据库 一,介绍 MongoDB是一种文档导向数据库管理系统,由C++撰写而成.介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作. Mongo ...

  4. C# Asp.net中简单操作MongoDB数据库(二)

    C# Asp.net中简单操作MongoDB数据库(一)    , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...

  5. C# Asp.net中简单操作MongoDB数据库(一)

    需要引用MongoDB.Driver.dll.MongoDB.Driver.core.dll.MongoDB.Bson.dll三个dll. 1.数据库连接: public class MongoDb ...

  6. PHP操作MongoDB 数据库

    最近有个项目,需要用php操作mongoDb数据,整理如下 1,连接MongoDB数据库 $conn = new Mongo(); 其他链接方式 //$conn=new Mongo(); #连接本地主 ...

  7. python操作三大主流数据库(10)python操作mongodb数据库④mongodb新闻项目实战

    python操作mongodb数据库④mongodb新闻项目实战 参考文档:http://flask-mongoengine.readthedocs.io/en/latest/ 目录: [root@n ...

  8. python操作三大主流数据库(9)python操作mongodb数据库③mongodb odm模型mongoengine的使用

    python操作mongodb数据库③mongodb odm模型mongoengine的使用 文档:http://mongoengine-odm.readthedocs.io/guide/ 安装pip ...

  9. python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查

    python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...

  10. python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用

    python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...

随机推荐

  1. mysql:通用查询日志general_log

    1.通用查询日志:记录建立的客户端连接和执行的语句,通用查询日志默认情况下不是开启的,通用查询日志是以文本方式存放的 当需要采样分析的时候手工开启: SET Global general_log=1; ...

  2. java中volatile关键字的含义 (转载)

    在java线程并发处理中,有一个关键字volatile的使用目前存在很大的混淆,以为使用这个关键字,在进行多线程并发处理的时候就可以万事大吉. Java语言是支持多线程的,为了解决线程并发的问题,在语 ...

  3. orale做报表常用函数和表达式的总结

    最近一段时间连续的做了几十张报表,通过原生sql对数据进行分析 ,也算是有了一定的了解,发现其中一些函数和表达式使用频率较高,现总结如下: (1).round()函数   round函数说白了就是把一 ...

  4. Android开发之Service

    什么是Service? Android中的服务与Activity不同,他是不能与用户进行交互,自己也不能启动在后台运行的程序,当我们退出应用时,Service应用并没有结束,它仍然在后台运行. 例子: ...

  5. Checkbox 全选、反选

    1.全选.反选 <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></t ...

  6. eclipse怎么切换SVN的用户

    在用eclipse的时候会经常用到SVN来进行代码的版本控制,为了方便起见,我们会保存密码,从此之后就不会再出现输入或者修改用户名和密码的地方了,这时候想切换用户怎么办,在本地操作的一种方法是删除SV ...

  7. ###Linux基础 - 2

    点击查看Evernote原文. #@author: gr #@date: 2014-10-13 #@email: forgerui@gmail.com 一.Linux基础命令2 mount: 挂载U盘 ...

  8. Bootstrap使用心得

    久闻Twitter的Bootstrap框架强大且易用,近日为改版小丸工具箱的官网特地花了一周实践. 这篇文章总结我在使用Bootstarp中的一些关键点. 1.布局 Bootstrap框架的布局采用了 ...

  9. [ADO.NET]写入数据

    关键字:.NET,SQL SERVER,SQLBULKCOPY 插入一条数据的操作(SqlCmd). public void InsertOneIntoSourceDB() { if (DBConne ...

  10. 用PL0语言求Fibonacci数列前m个中偶数位的数

    程序说明:求Fibonacci数列前m个中偶数位的数: 这是编译原理作业,本打算写 求Fibonacci数列前m个数:写了半天,不会写,就放弃了: 程序代码如下: var n1,n2,m,i; pro ...