最近比较忙,很久没更新了(虽然没人看,也没人在乎,也要记得be yourself),

  前面分享了一些mongodb的安装和简单的语法,今天模仿支付宝首页的模块移动功能,用mongo做一个简单的后台实例。

  one,启动本地的mongo服务like this.

  two,连接mongo可视化界面,建立PersonModule的文档集合。

  three,配置默认模块,我这边了个公共xml里。

<?xml version="1.0" encoding="utf-8" ?>

<root>
<model name="HomePage">
<nodes name="DefaulModule">
<node id="" name="转账"/>
<node id="" name="共享单车"/>
<node id="" name="电影票"/>
<node id="" name="出行"/>
</nodes>
</model >
</root>

  four,正式开工。

    1.初始化首页模块。

     /// <summary>
/// 初始化模块
/// </summary>
public void InitModule()
{
var DefaultModule = XmlHelper.GetXmlDic("HomePage", "DefaulModule");
var personModule = new PersonalModule();
List<BsonDocument> docs = new List<BsonDocument>();
//添加id=1,2,3三个人的首页模块
for (var i = ; i < ; i++)
{
personModule.PersonId = i;
personModule.Module = DefaultModule;
//一个人一个人添加
var json = JsonHelper.SerializeObject(personModule);
//mongoServer.Insert(collationName, json);
//批量添加
BsonDocument document = BsonDocument.Parse(json);
docs.Add(document);
}
//导入mongodb
mongoServer.ImportBatch("PersonModule", docs);
}

    2.个人PersonId=1的,添加模块(Id=5,Name=“余额”)

     /// <summary>
/// 添加模块
/// </summary>
public void AddModule()
{
var arrName = "Module";
var model = new Module() { Id = , Name = "余额" };
var json = JsonHelper.SerializeObject(model);
var filter = new BsonDocument();
// 更新条件
filter.Add("PersonId", );
//集合名称,查询条件,添加的对象,需要添加的数组名称
mongoServer.UpdatePushArray(collationName, filter, json, arrName);
}

    3.移除模块,移除个人PersonId=2,id=4的模块。

     /// <summary>
/// 移除模块
/// </summary>
public void RemoveModule()
{
var arrName = "Module";
var filter = new BsonDocument();
// 更新条件
filter.Add("PersonId", );
//移除PersonId=2的数组名称为"Module",id=4的对象
var doc = new BsonDocument() {
new BsonElement(arrName,
new BsonDocument() {
new BsonElement("Id", ) })};
mongoServer.UpdatePullArray(collationName, filter, doc);
}

    4.移动或者移动并删除模块

     /// <summary>
/// 移动或者移动并移除模块
/// </summary>
public void MoveModule()
{
var arrName = "Module";
// 更新条件
var filter = new BsonDocument();
filter.Add("PersonId", );
var moduleList = new List<Module>();
moduleList.Add(new Module { Id = ,Name= "共享单车" });
moduleList.Add(new Module { Id = , Name = "转账" });
moduleList.Add(new Module { Id = , Name = "出行" });
var json = JsonHelper.SerializeObject(moduleList);
mongoServer.UpdateArray(collationName, filter, json, arrName);
}

mongoServer类。

 public class MongoServer
{
private IMongoDatabase database = null;
private string server = System.Configuration.ConfigurationManager.AppSettings["MongoServer"];
private string port = System.Configuration.ConfigurationManager.AppSettings["MongoPort"];
private string db = System.Configuration.ConfigurationManager.AppSettings["DBName"];
public MongoServer()
{
Init();
}
public void Init()
{
var client = new MongoClient($"mongodb://{server}:{port}");
database = client.GetDatabase(db);
}
     /// <summary>
/// 查询一条
/// </summary>
/// <param name="tablename"></param>
/// <param name="query"></param>
/// <returns></returns>
public string FindOne(string tablename, BsonDocument filter)
{
var collection = database.GetCollection<BsonDocument>(tablename);
var documents = collection.Find(filter).FirstOrDefault();
return documents == null ? "" : documents.ToJson();
}
/// <summary>
/// update
/// </summary>
/// <param name="collectionName"></param>
/// <param name="filter"></param>
/// <param name="update"></param>
public void Update(string collectionName, BsonDocument filter, BsonDocument update)
{
var collection = database.GetCollection<BsonDocument>(collectionName);
collection.FindOneAndUpdate(filter, update);
}
/// <summary>
/// insert
/// </summary>
/// <param name="collectionName"></param>
/// <param name="json"></param>
public void Insert(string collectionName, string json)
{
var collection = database.GetCollection<BsonDocument>(collectionName);
BsonDocument document = BsonDocument.Parse(json);
collection.InsertOne(document);
}
/// <summary>
/// delete
/// </summary>
/// <param name="collectionName"></param>
/// <param name="json"></param>
public void Delete(string collectionName, BsonDocument query)
{
var collection = database.GetCollection<BsonDocument>(collectionName);
collection.FindOneAndDelete(query);
}
    /// <summary>
/// 批量导入
/// </summary>
/// <param name="collectionName"></param>
/// <param name="docs"></param>
public void ImportBatch(string collectionName, List<BsonDocument> docs)
{
var collection = database.GetCollection<BsonDocument>(collectionName);
collection.InsertMany(docs);
}
/// <summary>
/// 添加一条数组
/// </summary>
/// <param name="collectionName">集合名</param>
/// <param name="filter">条件</param>
/// <param name="json">更新内容</param>
/// <param name="arrayName">数组名</param>
public void UpdatePushArray(string collectionName, BsonDocument filter, string json, string arrayName)
{
//更新mongo简历
var update = new BsonDocument();
BsonDocument document = BsonDocument.Parse(json);
//添加doucment数组对象
update.Add("$push", new BsonDocument() { new BsonElement(arrayName, document) });
//更新修改时间
//update.Add("$set", new BsonDocument() {
// new BsonElement("",""),
// });
Update(collectionName, filter, update);
}
/// <summary>
/// 删除一条数组
/// </summary>
/// <param name="collectionName"></param>
/// <param name="filter"></param>
/// <param name="arrDoc"></param>
public void UpdatePullArray(string collectionName, BsonDocument filter, BsonDocument arrDoc)
{
//更新mongo简历
var update = new BsonDocument();
//$pull删除对象数组idName=id的对象文档
update.Add("$pull", arrDoc);
Update(collectionName, filter, update);
}
/// <summary>
/// 更新数组
/// </summary>
/// <param name="tableName"></param>
/// <param name="json"></param>
/// <param name="arrayName"></param>
public void UpdateArray(string collectionName, BsonDocument filter, string json, string arrayName)
{
//更新mongo简历
var update = new BsonDocument();
var update1 = new BsonDocument();
//删除原有数组文档
update.Set("$unset", new BsonDocument() { new BsonElement(arrayName, "") });
Update(collectionName, filter, update);
//set新的数组
json = "{ \"" + arrayName + "\" :" + json + "}";
BsonDocument document = BsonDocument.Parse(json);
update1.Set("$set", document);
Update(collectionName, filter, update1);
}
}

  最后,注意给document赋值时候的大小写问题。还有需要引用System.Runtime.InteropServices.RuntimeInformation包。

C#操作MongoDB的简单实例的更多相关文章

  1. python从入门到大神---4、python3文件操作最最最最简单实例

    python从入门到大神---4.python3文件操作最最最最简单实例 一.总结 一句话总结: python文件操作真的很简单,直接在代码中调用文件操作的函数比如open().read(),无需引包 ...

  2. MongoDB分片简单实例

    分片 在Mongodb里面存在另一种集群,就是分片技术,可以满足MongoDB数据量大量增长的需求. 当MongoDB存储海量的数据时,一台机器可能不足以存储数据也足以提供可接受的读写吞吐量.这时,我 ...

  3. nodejs+mongoose操作mongodb副本集实例

    继上一篇设置mongodb副本集之后,开始使用nodejs访问mongodb副本集: 1:创建项目     express 项目名称 2:npm install mongoose    安装mongo ...

  4. 关于MongoDB的简单理解(二)--Java篇

    一.声明 本文依赖于 MongoDB JVM DRIVERS 4.1 版本编写. 本文案例依赖于 Maven 项目管理工具. 二.本文主要讲解哪些内容? 如何连接到MongoDB 通过TLS/SSL连 ...

  5. 学习MongoDB--(11):应用举例(利用java操作MongoDB)

    原文地址:http://blog.csdn.net/drifterj/article/details/7948090 目录地址:http://blog.csdn.net/DrifterJ/articl ...

  6. 学习MongoDB-应用举例(利用java操作MongoDB)

    Java驱动程序是MongoDB最早的驱动,已用于生产环境很长时间,十分稳定.可以到MongoDB官方网站下载驱动,驱动版本为2.9.0. 这个jar文件中,有两个包,我们会经常用到com.mongo ...

  7. python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用

    python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...

  8. mongodb的简单操作记录

    由于项目上需要对mongodb进行监控,所以需要先熟悉下什么是mongobd以及mongodb的简单操作 mongodb的安装: curl -O https://fastdl.mongodb.org/ ...

  9. C# Asp.net中简单操作MongoDB数据库(二)

    C# Asp.net中简单操作MongoDB数据库(一)    , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...

随机推荐

  1. 原生js实现一个简单的倒计时功能

    大家好,我是云中君!欢迎大家来观看我的博客 之前那,在群里看到很多人问,关于电商网站中的倒计时功能怎么实现,很多人说在网上找了很多插件,但是不是很会用,所以今天就在这里分享一下我封装的一个小的倒计时功 ...

  2. 前端笔记----类型转换display

    display属性用来在行内元素,块元素,行内块元素之间进行转化. 常用的属性有: 1.none :元素隐藏且不占位置,相当于不存在,一般用在动态展示效果:2.block :元素以块元素显示,有些行内 ...

  3. Netty学习笔记(一):接收nodejs模拟表单上传的文件

    好久不写博客了,也好久不写代码了,这两天临时遇上一个事情,觉得不难,加上觉得手有些生,就动手做了一下,结果遇上了不少坑,有新坑,有老坑,痛苦无比,现在总算差不多了,赶紧记录下来,希望以后不再重复这种痛 ...

  4. UML2和建模工具学习总结

    软件发展的方向:CS–>BS–>SOA–>BIG DATA 建模的含义: 模型是对现实的简化 从特点视角对系统的一个完整性描述 建模的重要性: 为了更好的理解一个系统 管理复杂度(也 ...

  5. samba 搭建

    #useradd -M -s /sbin/nologin kvmshare #mkdir /home/etl #chown kvmshare:kvmshare /home/etl 将本地账号添加到 s ...

  6. java获取当前应用的运行信息(内存,线程,运行时间,状态等)

    一:目的 写这一段程序的原因是需要监控部署的的应用是否正常运行,并且显示其运行状态.在进程莫名死掉后甚至可以自动启动该应用. 首先这段代码可以获取的信息如下 /** * 当前进程运行的主机名 */ p ...

  7. python链接mysql

    1.安装MySQLdb MySQLdb 是用于Python链接Mysql数据库的接口,它实现了 Python 数据库 API 规范 V2.0,基于 MySQL C API 上建立的. 下载地址: ht ...

  8. ArcGIS 网络分析[2.4] OD成本矩阵

    什么是OD成本矩阵? 先不说这个东西是什么,我们还是举一个实际的例子: 现在存在3个城市北京.上海.武汉,请分析他们两两之间的通行时间. 很简单嘛!北京到上海,北京到武汉,上海到武汉都来一次最短路径分 ...

  9. bzoj 2002 HNOI 2010 弹飞绵羊

    Description 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始,Lostmonkey在地上沿着一条直线摆上n个装置,每个装置 ...

  10. win10下部署.Net Web项目到IIS10

    本问主要介绍如何将.Net Web项目部署到IIS10下面. 1.确保iis功能已开启 开启步骤如下:控制面板->程序 点击确定,ok,iis功能已开启. 2.打开iis,绑定站点到iis下面 ...