官网按需下载,安装,一步到位.
创建一个.netcoreconsole项目,然后nuget安装驱动MongoDB.Driver
在Program.Main函数中添加代码
varclient=newMongoClient("mongodb://127.0.0.1:27017"); vardatabase=client.GetDatabase("foo"); varcollection=database.GetCollection<BsonDocument>("bar");三个对象,client是连接数据库的客户端,database对应库,collection是对象集合.
对对象的操作是争对collection来的.
同理还有InsertMany(),鉴于VS高超的智能提示,一目了然.
上一步插入之后,通过find将它查找出来
find()需要一个filter参数,根据条件查询
collection.Find(Builders<BsonDocument>.Filter.Empty);上述表示无条件查询,matcheseverything.
如果有条件的话,可以从Builders.Filter中选择,比如Eq为相等,Lt为小于,Gt大于...顾名思义.基于VS强大的智能提示,非常清晰.
举例条件查询:
collection.Find(Builders<BsonDocument>.Filter.Eq("name","测试数据1")&Builders<BsonDocument>.Filter.Lt("number",6));多项条件之间的与或关系,对应使用&和|符号
更新使用UpdateMany(),同样支持条件从Builders.Filter中获取.
更新支持添加新的field,如:
collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("name","测试数据1"),Builders<BsonDocument>.Update.Set("number2",666));collection.DeleteMany()
其他几个API大同小异
不要引入Json.Net(Newtonsoft.Json)
扩展函数:
entity.ToBsonDocument()
通常是在Find的时候吧,IFindFluent.As()转就可以了.
varresult=collection .Find((Builders<BsonDocument>.Filter.Lt("number",999)&Builders<BsonDocument>.Filter.Gt("number",110))&Builders<BsonDocument>.Filter.Eq("name","测试数据1")) .OrderBy(x=>x["number"])//排序 .Skip(10)//跳过 .Limit(10)//限制 .As<Bar>()//m=>o .ToList();//像极了Linq吧?如果不是呢?
varentity=BsonSerializer.Deserialize<Bar>(bson);用到的自定义class大概长这样:
publicclassBar { publicObjectId_id{get;set;} publicstringname{get;set;} publicstringtype{get;set;} publicintnumber{get;set;} publicintnumber2{get;set;} publicBarInfoinfo{get;set;} publicclassBarInfo { publicintx{get;set;} publicinty{get;set;} } }mongodb对程序员是极友好的,可以动态变化的结构,让程序员不再害怕频繁变动的需求.
本文内容总结:一安装MongoDB,二VS创建新项目,三建立连接,四操作,1>插入,2>查找,3>更新,4>删除,五BsonDocument到自定义classObject的相互转换,1>自定义类型到BsonDocument,2>BsonDocument到自定义类型,小感想:,
原文链接:https://www.cnblogs.com/pasoraku/p/9634946.html