• 在C#中使用MongoDB


    一、添加MongoDB引用

    想要在C#中使用MongoDB,首先得要有个MongoDB支持的C#版的驱动。

    利用MongoDB官方发布的C#驱动,可通过网络下载或nuget安装,得到MongoDB相关的dll,添加到项目中引用。这里介绍下通过NuGet方式添加

    第一步:在项目中右键,选择管理NuGet管理包

    image

    第二步:搜索MongoDB,选择MongoDB.Driver添加,我这里已经添加过了所以没有添加按钮

    image

    通过这两步,会在项目中自动添加MongoDB.Bson、MongoDB.Driver、MongoDB.Driver.Core等引用

    MongoDB.Driver.dll:顾名思义,驱动程序

    MongoDB.Bson.dll:序列化、Json相关

    image


    二、使用方法

    1、连接数据库

    在连接数据库之前,请确保MongoDB数据库服务已经启动。

    //1.连接字符串(mongodb数据库默认端口为:27017)
    string connStr = "mongodb://127.0.0.1:27017";
    
    //2.创建连接MongoClient实例实际上代表了一个到数据库的连接池,即使有多个线程,也只需要一个MongoClient类的实例
    var client = new MongoDB.Driver.MongoClient(connStr);
    
    //3.使用client的GetDatabase方法获取数据库,即使该数据库不存在,也会自动创建;
    IMongoDatabase db = client.GetDatabase("test");

    2、操作数据

    三个对象, client是连接数据库的客户端, database对应库, collection是对象集合。对对象的操作是针对collection。

    //4.获取数据集 collection;BsonDocument是在数据没有预先定义好的情况下使用的。
    IMongoCollection<BsonDocument> collection = db.GetCollection<BsonDocument>("runoob1");
    
    //5.插入一条数据;
    var document = new BsonDocument { { "id", 2 }, { "name", "aa" } };
    collection.InsertOne(document);
    
    
    //6.查询数据1
    var res = collection.Find(new BsonDocument()).ToList(); //查询整个数据集
    foreach (var item in res)
    {
        Console.WriteLine(item);
    }
    //6.查询数据2
    var res_a = collection.Find(new BsonDocument()).FirstOrDefault(); //查询当前数据集的第一条数据,没有则返回null
    Console.WriteLine(res_a);
    
    
    //6.升序降序查询3:
    var sort_ascending = Builders<BsonDocument>.Sort.Ascending("id"); //根据id升序
    var sort_descending = Builders<BsonDocument>.Sort.Descending("id"); //根据id降序
    var res_c = collection.Find(Builders<BsonDocument>.Filter.Lt("id", 10) & Builders<BsonDocument>.Filter.Gte("id", 2)).Limit(50).ToCursor(); //查询id小于10,大于2的数据
    foreach (var item in res_c.ToEnumerable())
    {
        Console.WriteLine(item);
    }
    
    //7.更新数据,更新支持添加新的field, 如:
    collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("id", 2), Builders<BsonDocument>.Update.Set("name", "hello"));   //将id字段为2的名字都改为“hello”;
    
    //8.删除
    collection.DeleteMany(Builders<BsonDocument>.Filter.Eq("id", 2));

    mongodb对程序员是极友好的, 可以动态变化的结构, 让程序员不再害怕频繁变动的需求.

  • 相关阅读:
    POJ1028 Web Navigation【堆栈+模拟】
    UVa10276 HDU1329 ZOJ1239 Hanoi Tower Troubles Again!【递推函数+打表】
    UVALive5369 UVa732 HDU1515 ZOJ1004 Anagrams by Stack【DFS+堆栈】
    HDU5776 sum【前缀和+模除】
    POJ1844 Sum【水题+数学题】
    AOJ0558 Cheese【BFS】
    POJ3009 Curling 2.0【DFS】
    HDU1163 Eddy's digital Roots(解法二)【快速模幂+九余数定理】
    HDU1210 Eddy's 洗牌问题【递推函数+模拟】
    Vijos P1571 笨笨的导弹攻击【最长上升子序列+DP】
  • 原文地址:https://www.cnblogs.com/springsnow/p/13093956.html
Copyright © 2020-2023  润新知