Mongodb是一种比较常见的NOSQL数据库,数据库排名第四,今天介绍一下Net Core 下,常规操作。

首先下C# 版的驱动程序 “MongoDB.Driver”,相关依赖包自行引用进来。 过于细节的基础知识就不讲了,直接就奔主题了

using MongoDB.Driver; //命名空间
MongoClient client = new MongoClient("mongodb://192.168.99.5");
IMongoDatabase dbBase = client.GetDatabase("School");

Mongodb有一个特性,你可以不用先建数据库和集合,数据库会自行检查,如果没有就新建。

IMongoCollection<> collection = dbBase.GetCollection<>("Class"); //获取集合
GetCollection是一个泛型方法,你可以输入BsonDocument,或者实体,Mongodb驱动程序会自动帮你序列化
IMongoCollection<BsonDocument> collection = dbBase.GetCollection<BsonDocument>("Class");
  public class Class
    {
        public BsonObjectId Id { set; get; }

        public string ClassName { set; get; }

        public List<Student> StudentItems { set; get; }
    }

    public class Student
    {
        public string Name { set; get; }

        public int Age { set; get; }

        public string Sex { set; get; }
    }

  IMongoCollection<Class> collection = dbBase.GetCollection<Class>("Class");

如果你使用BsonDocument,那么你会得么一个BsonDocument对象,Mongodb驱动程序内置了序列化方法,方便将BsonDocument转换成实体对象。

using MongoDB.Bson.Serialization;//命名空间
var schoolClass = BsonSerializer.Deserialize<Class>(new BsonDocument());

Mongodb驱动程序支持Linq 语法,你可以借此写出优雅语句。

var schoolClass = collection.Find(n => n.ClassName == "一年级").FirstOrDefault();
var schoolClass2 = collection.AsQueryable<Class>().Where(n => n.ClassName == "一年级").FirstOrDefault();
var schoolClass3 = collection.Find(new BsonDocument("ClassName", "一年级")).FirstOrDefault();

Mongodb驱动程序还支持异步方法,根据命名约定,很多方法相应的Async结尾的,都是异步方法。

var schoolClass = await collection.Find(n => n.ClassName == "一年级").FirstOrDefaultAsync();
var schoolClass2 = await  collection.AsQueryable<Class>().Where(n => n.ClassName == "一年级").FirstOrDefaultAsync();
var schoolClass3 = await  collection.Find(new BsonDocument("ClassName", "一年级")).FirstOrDefaultAsync();

基本介绍完毕,下面进入增删更改的操作方法。

---------------------------增加---------------------------------


IMongoCollection<Class> collection = dbBase.GetCollection<Class>("Class");
//写入单个
collection.InsertOne(new Class
{
    ClassName = "二年级",
    StudentItems = new List<Student>
    {
        ,Name="李明",Sex="男" },
        ,Name="小红",Sex="女" }
    }
});
//批量写入
collection.InsertMany(new List<Class>
{
    new Class
    {
        ClassName = "二年级",
        StudentItems = new List<Student>
        {
            ,Name="李明",Sex="男" },
            ,Name="小红",Sex="女" }
        }
    }
});
IMongoCollection<BsonDocument> collection = dbBase.GetCollection<BsonDocument>("Class");
//写入单个
collection.InsertOne(new BsonDocument {
    {"ClassName","二年级" },
    {"StudentItems",new BsonArray{
             },{ "Name", "李明" },{ "Sex", "男" } }
        }
    }
});
//批量写入
collection.InsertMany(new List<BsonDocument>
{
    new BsonDocument {
    {"ClassName","二年级" },
    {"StudentItems",new BsonArray{
             },{ "Name", "李明" },{ "Sex", "男" } }
        }
    } },
    new BsonDocument {
    {"ClassName","二年级" },
    {"StudentItems",new BsonArray{
             },{ "Name", "李明" },{ "Sex", "男" } }
        }
    } }
});

不过,使用C#语言,我还是尽量推荐使用实体来添加,可读性,维护性也强。也有缺点,JSON结构如果使用实体话,类库较大,庆幸的Mongodb驱动程序可以帮你序列化。

BsonDocument结构虽然符合JSON,用起来却很痛苦,不过也减少类库的数量。

---------------------------删除---------------------------------

IMongoCollection<Class> collection = dbBase.GetCollection<Class>("Class");
//删除单个
collection.DeleteOne(n => n.ClassName == "二年级");//使用拉姆达表达式
collection.DeleteOne(new BsonDocument("ClassName", "二年级"));//使用BsonDocument
var filter = Builders<Class>.Filter.Eq("_id", new BsonObjectId("5a545e9381a98c3ab46c9cb9"));
collection.DeleteOne(filter);//使用Builders,
//批量删除
collection.DeleteMany(n => n.ClassName == "二年级");
collection.DeleteMany(new BsonDocument("ClassName", "二年级"));
collection.DeleteMany(filter);
//删除并返回
collection.FindOneAndDelete(n => n.ClassName == "三年级");
IMongoCollection<BsonDocument> collection = dbBase.GetCollection<BsonDocument>("Class");
//删除单个
collection.DeleteOne(new BsonDocument("ClassName", "二年级"));//使用BsonDocument
var filter = Builders<BsonDocument>.Filter.Eq("_id", new BsonObjectId("5a545e9381a98c3ab46c9cb9"));
collection.DeleteOne(filter);//使用Builders,
//批量删除
collection.DeleteMany(new BsonDocument("ClassName", "二年级"));
collection.DeleteMany(filter);
//删除并返回
collection.FindOneAndDelete(new BsonDocument("ClassName", "二年级"));

使用BsonDocument,就不能使用酷酷的拉姆达表达式了,其它的差不多。

---------------------------更改---------------------------------

IMongoCollection<Class> collection = dbBase.GetCollection<Class>("Class");
//修改单个
var filter = Builders<Class>.Filter.Eq("_id", new BsonObjectId("5a545e9381a98c3ab46c9cb8"));
var update = Builders<Class>.Update.Set("ClassName", "三年级");
var update2 = Builders<Class>.Update.Set(n => n.ClassName, "三年级");

collection.UpdateOne(n => n.ClassName == "二年级", update);//使用拉姆达表达式
collection.UpdateOne(filter, update2);//使用Builders
//批量修改
collection.UpdateMany(n => n.ClassName == "二年级", update);
collection.UpdateMany(filter, update2);
//替换
var schoolClass = collection.Find(n => n.ClassName == "二年级").FirstOrDefault();
collection.ReplaceOne(n => n.ClassName == "二年级", schoolClass);

使用BsonDocument 也是相应差不多,我就不贴出代码了。

修改数组,则大概如下

//数组增加一个
, Name = "张明", Sex = "男" });
collection.UpdateOne(n => n.ClassName == "三年级", update);
//数组减少一个
, Name = "张明", Sex = "男" });
collection.UpdateOne(n => n.ClassName == "三年级", update2);
//数组修改一个
);
collection.UpdateOne(n => n.ClassName == ), update3);
, Name = "张明", Sex = "男" });
collection.UpdateOne(n => n.ClassName == ), update4);

示例是筛选过,不能每种写法写出来,读者自行试尝组合

---------------------------查询---------------------------------

var shoolClass = collection.Find(n => n.ClassName == "三年级").FirstOrDefault();//使用拉姆达表达式
var shoolClassItems = collection.Find(n => n.ClassName == "三年级").ToList();
var shoolClass2 = collection.Find(new BsonDocument("ClassName", "三年级")).FirstOrDefault();
var shoolClassItems2 = collection.Find(new BsonDocument("ClassName", "三年级")).ToList();
var filter = Builders<Class>.Filter.Eq(n => n.ClassName, "三年级");//使用Builders
var shoolClass3 = collection.Find(filter).FirstOrDefault();
var shoolClassItems3 = collection.Find(filter).ToList();

Mongodb的基本应用,就讲解完毕,笔记一下

Mongodb常规操作【一】的更多相关文章

  1. mongodb常规操作语句

    db.c_user.insertOne({ name: "ljm", pwd: "123456" }); //插入一个 db.c_user.insertMany ...

  2. mongodb基础整理篇————常规操作[二]

    前言 简单整理一下常规操作. 正文 虽然一般说写代码看的是思想,但是呢,如果不知道mongodb 有哪些常用的操作,那么你怎么能知道mongodb是否符合你的需求,比如说如果聚合功能都没有,你得自己写 ...

  3. MongoDB查询操作限制返回字段的方法

    这篇文章主要介绍了MongoDB查询操作限制返回字段的方法,需要的朋友可以参考下   映射(projection )声明用来限制所有查询匹配文档的返回字段.projection以文档的形式列举结果集中 ...

  4. EasyUI-datagrid数据展示+MongoDB数据操作

    使用EasyUI-datagrid进行数据展示:进行添加,修改,删除操作逻辑代码,数据源来自MongoDB. 一.新建SiteInfo控制器,添加Index页面:http://www.cnblogs. ...

  5. Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作

    2 Mongodb CRUD 操作 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mong ...

  6. FTP服务器常规操作

    导读 FTP协议是Internet文件传输的基础,它是由一系列规格说明文档组成,目标是提高文件的共享性,提供非直接使用远程计算机,使存储介质对用户透明和可靠高效地传送数据.下面就由我给大家简单介绍一下 ...

  7. Apache服务器常规操作

    导读 Apache是世界上排名第一的Web服务器,50%以上的Web服务器都在使用Apache,它几乎可以在所有计算机平台上运行.下面就由我给大家说说Apache服务器的一些常规操作. Apache服 ...

  8. mysql服务器的常规操作

    mysql服务器的常规操作 导读 MySQL是一个小型关系数据库管理系统,目前被广泛的应用在Internet上的中小型网站中,体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,使得许多中小型网站 ...

  9. 征服 Redis + Jedis + Spring (一)—— 配置&常规操作(GET SET DEL)

    有日子没写博客了,真的是忙得要疯掉. 完成项目基础架构搭建工作,解决了核心技术问题,接着需要快速的调研下基于Spring框架下的Redis操作. 相关链接: 征服 Redis 征服 Redis + J ...

随机推荐

  1. 联动加入redmine的wik

    <? php error_reporting(E_ERROR); date_default_timezone_set('Asia/Shanghai'); $red_server = " ...

  2. Qt之QHeaderView加入复选框

    简述 前面分享了QTableView中怎样加入复选框. 本节主要介绍QTableView中的表头-QHeaderView加入复选框的功能,以下以水平表头为例.垂直表头相似! 简述 效果 QHeader ...

  3. js清除cookie有时无法清除

    最近写页面遇到一个问题,退出的时候需要清除cookie,但是刚开始一直清除不掉,代码如下: //清除函数 function delCookie(name) { var date= new Date() ...

  4. 【quickhybrid】API的分类:短期API、长期API

    前言 一切就绪,开始规划API,这里在规划前对API进行了一次分类:短期API.长期API 首先申明下,这个是在实际框架演变过程中自创的一个概念,其它混合框架可能也会有这个概念,但应该是会在原生底层来 ...

  5. 自学Zabbix3.6.2-触发器triggers severity严重程度

    触发器严重性定义了触发器的重要性. 1. zabbix支持以下触发级别: SEVERITY DEFINITION 颜色 Not classified 未知. 灰色 Information 一般信息. ...

  6. Redis 订阅发布 - Jedis实现

    Redis 订阅发布 - Jedis实现 我想到使用Redis的订阅发布模式是用来解决推送问题的-. 对于概念性的叙述,多多少少还是要提一下的: ​ 什么是Redis发布订阅?Redis发布订阅是一种 ...

  7. css经典布局—stick footer布局

    html部分 <div id="wrap"> <div id="main" class="clearfix"> &l ...

  8. 教程:安装禅道zentao项目管理软件github上的开发版

    该文章转自:吕滔博客 直接从github拉下来的禅道的源码,是跑不起来的.除非你按我的教程来做...哈哈哈(不要脸)~~~~ 禅道官网提供的版本包是带了有安装文件,并有打包合成一些css.js文件的. ...

  9. JDBC开源框架:DBUtils使用入门

    在单元测试过程中,只涉及到数据库的直接操作来验证业务逻辑是否正确的情况,DBUtils非常适合使用.它结构简单,包小,友好处理掉那些jdbc异常,让你更专注于业务代码,而非底层的操作.官网对它的定义: ...

  10. Hibernate学习---单表查询

    我们都知道SQL是非常强大的,为什么这么说呢?相信学过数据库原理的同学们都深有体会,SQL语句变化无穷,好毫不夸张的说可以实现任意符合我们需要的数据库操作,既然前面讲到Hibernate非常强大,所以 ...