MongoDB(10):在C#中使用MongoDB
一、添加MongoDB引用
想要在C#中使用MongoDB,首先安装支持MongoDB的C#版的驱动。
利用MongoDB官方发布的C#驱动,可通过网络下载或nuget安装,得到MongoDB相关的dll,添加到项目中引用。
https://docs.mongodb.com/drivers/csharp/
1、通过NuGet方式添加
第一步:在项目中右键,选择管理NuGet管理包
第二步:搜索MongoDB,选择MongoDB.Driver添加,我这里已经添加过了所以没有添加按钮
通过这两步,会在项目中自动添加MongoDB.Bson(序列化、Json相关)、MongoDB.Driver(驱动程序)、MongoDB.Driver.Core等引用
二、使用方法
1、连接数据库
在连接数据库之前,请确保MongoDB数据库服务已经启动。
using MongoDB.Bson; using MongoDB.Driver; //1.连接字符串(mongodb数据库默认端口为:27017) string connStr = "mongodb://127.0.0.1:27017"; //2.创建连接MongoClient实例实际上代表了一个到数据库的连接池,即使有多个线程,也只需要一个MongoClient类的实例 var client = new 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).Sort(sort_ascending).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对程序员是极友好的, 可以动态变化的结构, 让程序员不再害怕频繁变动的需求。
posted on 2020-06-11 16:16 springsnow 阅读(5756) 评论(0) 编辑 收藏 举报