一、准备工作
工欲善其事必先利其器,首先呢咱们得下载好C#程序里面可以驱动mongodb的组件:
走起官网:C#操作mongodb组件下载
菜鸟教程也上一上:mongodb菜鸟教程
dll下载下来之后有这几个,都引用上,不要省,哈哈!个人还是习惯直接下载下来,不走Nget的模式,那玩意菜鸟学不会。
为啥要加上xml呢,这你就不懂了,你难道没发现加了之后使用方法的时候,有了说明了么?就是这么优秀的一个操作。
二、开始实操增删改查
做好准备工作,下面咱们开始实操,把增删改查给你走一遍,看好喽,打起精神!
话不多话,咱先上代码,以后看到只说不做,特别是不放完整源代码的博主,咱们就得讲他耍流氓,咱可不做这类型的人,直接贴代码,优秀的人做事一向就是这么直接。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Text;
using MongoDB.Bson;
using MongoDB.Bson.Serialization.Attributes;
using MongoDB.Driver;
namespace MongoDbSpider
{
/// <summary>
/// MongoDb 数据库操作类
/// </summary>
public class MongoDbHelper
{
/// <summary>
/// 数据库对象
/// </summary>
private IMongoDatabase _dataBase;
/// <summary>
/// 构造函数
/// </summary>
/// <param name="conStrMdb">连接字符串</param>
public MongoDbHelper(string conStrMdb)
{
this._dataBase = GetDb(conStrMdb);
}
/// <summary>
/// 若没有,根据传入的数据库名字来生成对应的数据库名,否则,返回db
/// </summary>
/// <param name="conStrMdb">数据库连接</param>
/// <returns></returns>
public IMongoDatabase GetDb(string conStrMdb)
{
var db = new MongoClient(conStrMdb).GetDatabase(new MongoUrlBuilder(conStrMdb).DatabaseName);
return db;
}
/// <summary>
/// 创建集合对象
/// </summary>
/// <param name="collName">集合名称</param>
///<returns>集合对象</returns>
private IMongoCollection<T> GetColletion<T>(string collName)
{
return _dataBase.GetCollection<T>(collName);
}
/// <summary>
/// 获取指定数据库集合中的所有的文档
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="tableName">表名</param>
/// <returns></returns>
public List<T> FindAll<T>(string tableName)
{
List<T> list = new List<T>();
try
{
var collection = GetColletion<T>(collName: tableName);
FilterDefinition<T> filter =