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 ...
随机推荐
- boost--线程
1.thread的使用 boost的thread包含了线程创建.使用.同步等内容,使用thread需要包含头文件"boost\thread.hpp". thread中使用了需要编 ...
- 安卓TP驱动开发
转自 blog.csdn.net/dddxxxx/article/details/54312415
- WordPress-Word图片上传插件整合教程-Xproer.WordPaster
插件下载(PHP):wordpress 3.7.1, 说明:由于许多插件可能使用相同钩子,导致冲突,所以提供手支方式整合. 1.上传插件目录. 说明:WordPress 3.7.1 使用的是TinyM ...
- linux下修改root密码以及找回密码的方法
以root身份登陆,执行: # passwd 用户名 (修改密码) # useradd 用户名 (添加用户) 具体示例如下:[root@bogon ~]# passwd root Changing p ...
- POJ2456--Aggressive cows(Binary Search) unsolved
Description Farmer John has built a new long barn, with N (2 <= N <= 100,000) stalls. The stal ...
- js-倒计时应用
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> ...
- Python自动化开发 - 流程控制
一.拾遗主题 1.变量 理解变量在计算机内存中的表示 >>> a = "ABC" Python解释器干了两件事情: 在内存中创建了一个'ABC'的字符串: 在内存 ...
- iOS 应用如何完全支持 IPv6-ONLY 网络?
iOS 应用如何完全支持 IPv6-ONLY 网络?¶ 警告 您当前查看的页面是未经授权的转载! 如果当前版本排版错误,请前往查看最新版本:http://www.cnblogs.com/qin-nz/ ...
- Web应用安全之Response Header里的敏感信息
Web应用安全之Response Header 文/玄魂 目录 Web应用安全之Response Header 前言 1.1 那些敏感的header 1.2 删除敏感的header 1.2.1 删除 ...
- WPF实战案例-数据代理
在我们wpf开发中,很多人会有mvvm模式去做wpf的项目. 是否有人遇到这样一个场景:在一个界面上,有个tabcontrol上面有4个页签,每个页签里面都有一个datagrid,里面显示的列基本一样 ...