mongodb netcore 操作封装_.net Core MongoDB用法演示

C#驱动MongoDB的本质是将C#的操作代码转换为mongo shell,驱动的API也比较简单明了,方法名和js shell的方法名基本都保持一致,熟悉mongo shell后学习MongoDB的C#驱动是十分轻松的,直接看几个demo吧。

0.准备测试数据

使用js shell添加一些测试数据,如下:

use myDb

db.userinfos.insertMany([

{_id:1, name: "张三", age: 23,level:10, ename: { firstname: "san", lastname: "zhang"}, roles: ["vip","gen"]},

{_id:2, name: "李四", age: 24,level:20, ename: { firstname: "si", lastname: "li"}, roles:[ "vip"]},

{_id:3, name: "王五", age: 25,level:30, ename: { firstname: "wu", lastname: "wang"}, roles: ["gen","vip"]},

{_id:4, name: "赵六", age: 26,level:40, ename: { firstname: "liu", lastname: "zhao"}, roles: ["gen"] },

{_id:5, name: "田七", age: 27, ename: { firstname: "qi", lastname: "tian"}, address:'北京'},

{_id:6, name: "周八", age: 28,roles:["gen"], address:'上海'}

])

1 添加(InsertOne,InsertMany)

安装nuget包(或者执行命令  Install-Package MongoDB.Driver)

然后就可以使用C#操作MongoDB数据库了,看一个添加的demo:

classProgram

{static void Main(string[] args)

{//连接数据库

var client = new MongoClient("mongodb://root:root@192.168.100.3:27017/");//获取database

var mydb = client.GetDatabase("myDb");//获取collection

var collection = mydb.GetCollection("userinfos");//待添加的document

var doc = newBsonDocument{

{"_id",7},

{"name", "吴九"},

{"age", 29},

{"ename", newBsonDocument

{

{"firstname", "jiu"},

{"lastname", "wu"}

}

}

};//InsertOne()添加单条docment

collection.InsertOne(doc);

}

}

执行完成后,查看在NoSQLBooster中查询,看到已经添加成功了:

我们也可以是用 collection.InsertMany(IEnumerable docs) 来批量添加docment,这里就不再演示了。

2  查询(Find,Filter,Sort,Projection)

1.简单查询(Find、Filter)

查找name=“吴九"的记录

var client = new MongoClient("mongodb://root:root@192.168.100.3:27017/");//获取database

var mydb = client.GetDatabase("myDb");//获取collection

var collection = mydb.GetCollection("userinfos");//Fileter用于过滤,如查询name = 吴九的第一条记录

var filter = Builders.Filter;//Find(filter)进行查询

var doc = collection.Find(filter.Eq("name", "吴九")).FirstOrDefault();

Console.WriteLine(doc);

查询结果如下:

如果我们想查询所有的记录,可以设置过滤器为空,代码为: var docs = collection.Find(filter.Empty).ToList();

2.AND查询

查询年龄大于25且小于28的记录

//连接数据库

var client = new MongoClient("mongodb://root:root@192.168.100.3:27017/");//获取database

var mydb = client.GetDatabase("myDb");//获取collection

var collection = mydb.GetCollection("userinfos");//查询25

var filter = Builders.Filter;var docs = collection.Find(filter.Gt("age", 25) & filter.Lt("age", 28)).ToList();

docs.ForEach(d&#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
操作monodb的c#封装,调用非常方便,可以继承,功能包括: 1、所有数据库操作 2、前台表格类数据获取 public List GetList(List lstColName, Document query, JqGridParam jqParam, ref int count),封装了通用的获取前台表格数据的方法,将在工程中减少大量数据库访问代码,有了这个后对前台表格类查询我们可以不用在Control里使用linq或者封装在Model里然后对前台定义视图类了,使用如下: try { JqGridParam jqParam = new JqGridParam(); jqParam.page = 1; jqParam.rows = 1000; MemberOper memOper = new MemberOper(); MongoBasicOper monOper = new MongoBasicOper(DTName.GROUP_MEMBER); int count = 0; //过滤条件 Document query = new Document(); if (!string.IsNullOrEmpty(find)) { MongoRegex reg = new MongoRegex(".*" + find + ".*"); query.Add(DColName.Name, reg); } query.Add(DColName.GroupId, g); Document[] docStatus = new Document[] { new Document(DColName.Status, RowStatus.Pass), new Document(DColName.Status, RowStatus.Admin) }; query.Add("$or", docStatus); //查询列 List lstColName = new List(); lstColName.Add(DColName.UserId); lstColName.Add(DColName.UserName); //查询数据 var lstRes = monOper.GetListEx(lstColName, query, jqParam, ref count); //转换返回值 JqGrid jg = new JqGrid(); if (count == 0) { return Json(jg.toNull(jqParam), JsonRequestBehavior.AllowGet); } var jsonData = jg.toJson(jqParam, count, lstRes, lstColName); jsonData.param = g; return Json(jsonData, JsonRequestBehavior.AllowGet); } catch (Exception e) { return Json(e.Message, JsonRequestBehavior.AllowGet); }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值