C#简单操作MongoDB
一 安装MongoDB
官网按需下载, 安装, 一步到位.
二 VS创建新项目
创建一个.netcore console项目, 然后nuget安装驱动MongoDB.Driver
三 建立连接
在Program.Main函数中添加代码
var client = new MongoClient("mongodb://127.0.0.1:27017");
var database = client.GetDatabase("foo");
var collection = database.GetCollection<BsonDocument>("bar");
三个对象, client是连接数据库的客户端, database对应库, collection是对象集合.
对对象的操作是争对collection来的.
四 操作
1> 插入
var document = new BsonDocument
{
{ "name", "测试数据1" },
{ "type", "大类" },
{ "number", },
{ "info", new BsonDocument
{
{ "x", },
{ "y", }
}}
};
collection.InsertOne(document);
同理还有InsertMany(), 鉴于VS高超的智能提示, 一目了然.
2> 查找
上一步插入之后, 通过find将它查找出来
find()需要一个filter参数, 根据条件查询
collection.Find(Builders<BsonDocument>.Filter.Empty);
上述表示无条件查询, matches everything.
如果有条件的话, 可以从Builders<BsonDocument>.Filter中选择, 比如Eq为相等, Lt为小于, Gt大于...顾名思义. 基于VS强大的智能提示, 非常清晰.
举例条件查询:
collection.Find(Builders<BsonDocument>.Filter.Eq("name", "测试数据1") & Builders<BsonDocument>.Filter.Lt("number", ));
多项条件之间的与或关系, 对应使用&和|符号
3> 更新
collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("name", "测试数据1"), Builders<BsonDocument>.Update.Set("number", 6));
更新使用UpdateMany(), 同样支持条件从Builders<BsonDocument>.Filter中获取.
更新支持添加新的field, 如:
collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("name", "测试数据1"), Builders<BsonDocument>.Update.Set("number2", ));
4> 删除
collection.DeleteMany()
其他几个API大同小异
五 BsonDocument到自定义class Object的相互转换
不要引入Json.Net(Newtonsoft.Json)
1> 自定义类型到BsonDocument
扩展函数:
entity.ToBsonDocument()
2> BsonDocument到自定义类型
通常是在Find的时候吧, IFindFluent.As<TEntity>()转就可以了.
var result = collection
.Find((Builders<BsonDocument>.Filter.Lt("number",) & Builders<BsonDocument>.Filter.Gt("number", )) & Builders<BsonDocument>.Filter.Eq("name", "测试数据1"))
.OrderBy(x=>x["number"])//排序
.Skip()//跳过
.Limit()//限制
.As<Bar>()//m=>o
.ToList();//像极了Linq吧?
如果不是呢?
var entity = BsonSerializer.Deserialize<Bar>(bson);
用到的自定义class大概长这样:
public class Bar
{
public ObjectId _id { get; set; }
public string name { get; set; }
public string type { get; set; }
public int number { get; set; }
public int number2 { get; set; }
public BarInfo info { get; set; } public class BarInfo
{
public int x { get; set; }
public int y { get; set; }
}
}
小感想:
mongodb对程序员是极友好的, 可以动态变化的结构, 让程序员不再害怕频繁变动的需求.
C#简单操作MongoDB的更多相关文章
- C# Asp.net中简单操作MongoDB数据库(二)
C# Asp.net中简单操作MongoDB数据库(一) , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...
- C# Asp.net中简单操作MongoDB数据库(一)
需要引用MongoDB.Driver.dll.MongoDB.Driver.core.dll.MongoDB.Bson.dll三个dll. 1.数据库连接: public class MongoDb ...
- Python学习笔记_03:简单操作MongoDB数据库
目录 1. 插入文档 2. 查询文档 3. 更新文档 4. 删除文档 1. 插入文档 # -*- coding: UTF-8 -*- import datetime from pymongo im ...
- mongodb的简单操作记录
由于项目上需要对mongodb进行监控,所以需要先熟悉下什么是mongobd以及mongodb的简单操作 mongodb的安装: curl -O https://fastdl.mongodb.org/ ...
- PHP使用MongoDB类操作MongoDB数据库总结
参考:https://www.php.net/manual/zh/class.mongodb-driver-manager.php 参考:https://www.zhaokeli.com/articl ...
- .Net Core MongoDB 简单操作。
一:MongoDB 简单操作类.这里引用了MongoDB.Driver. using MongoDB.Bson; using MongoDB.Driver; using System; using S ...
- C# 对MongoDB 进行增删改查的简单操作
C# 对MongoDB 进行增删改查的简单操作 下面演示下C#操作MongoDB驱动的简单的增删改查代码 运用到的MongoDB支持的C#驱动,当前版本为1.6.0 1,连接数据库 /// & ...
- MongoDB数据库简单操作
之前学过的有mysql数据库,现在我们学习一种非关系型数据库 一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数 ...
- python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用
python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...
随机推荐
- C语言常用数据类型说明
1.取值范围: short一般占两个字节,取值范围:-32768 - 32767 int一般占两个或四个字节,取值范围:-2147483648 - 2147483647 unsigned int ...
- idea中Eclipse Code Formatter插件设置和使用,以及注释模板的修改
在settings里面找到plugins这个选项,搜索Eclipse Code Formatter,点击安装,重启idea即可进行配置: 首先,先安装Eclipse Code Formatter插件: ...
- Mybatis-Plus 实战完整学习笔记(六)------select测试一
查询方法(3.0.3) 1.查询一个员工的数据 @Test public void selectMethod() throws SQLException { // 根据ID获取一个对象的数据 Empl ...
- AngularJS实战之cookie的读取
<!DOCTYPE html> <html ng-controller="cookies_controller"> <head> <tit ...
- C#的math类的全部运算方法
Abs 返回指定数字的绝对值.Acos 返回余弦值为指定数字的角度.Asin 返回正弦值为指定数字的角度.Atan 返回正切值为指定数字的角度.Atan2 返回正切值为两个指定数字的商的角度.BigM ...
- 关于Lambda
1. 查询时,包含关联子对象.如: 数据库中包含表Father和Son,映射实体如下: public class Father { public string Name{get;set;} publi ...
- Windows 8.1 Update中的小改变
在Build 2014大会中,发布了Windows 8.1 Update的更新,并将于4月8日通过Windows Update进行推送.但是,在MSDN订阅下载中,带有该更新的镜像已经可以在4月3号放 ...
- HDU2955 01背包
http://acm.hdu.edu.cn/showproblem.php?pid=2955 题目大意:给你一个劫匪抢银行的最高安全概率,给你银行得到钱数,和劫匪在这个银行可以逃跑的概率,问你最多能抢 ...
- 3.1.1随机事件的概率的Breamer(2018-03-22)
% !Mode:: "TeX:UTF-8" \documentclass[xcolor=svgnames,serif,table,12pt]{beamer}%, %\include ...
- 中美会计准则差异比较(PRC GAAP VS US GAAP)
http://bbs.chinaacc.com/forum-2-43/topic-2023118.html 一.中美会计准则的实质性差别 rule based vs principle base ...