Mongodb 官网驱动2.2.4.26版本 增,删 改,查,mongodb2.2.4.26
Mongodb是3.2.7版本
最近在学习mongodb数据库在网上找到的都不是2.X版本以下的,因为驱动从2.X以后修改了很多,以前不支持linq现2.X也支持了,
Mongodb 启动服务就不说了现在就来看看基本的操作
上代码:
首先定义一个模型用来测试操作
public class Persion
{
//引用using MongoDB.Bson.Serialization.Attributes;
[BsonId]
public string _id;
public string Name;
public int age;
public string Email;
public string TableName
{
get{return "persion"; }
}
}
将mongob C#driver 添加到引用,引用方式可以通过Nuget添加 或者直接到官网去下载然后添加到项目中,
配置创建mongodbClient 注:【以前的版本是MongoServer】并做好配置
地址可以使用远程的或者是本地的,现在是使用本地的
//数据库连接字符串
static string conn = "mongodb://127.0.0.1:27017";
//数据库名称
static string database = "appdb";//数据库名
static MongoUrl url = new MongoUrl(conn);
static MongoClient ci = new MongoClient(url);//创建mongoClient
static IMongoDatabase db = ci.GetDatabase(database);//获取数据库
以下就是数据的具体操作方法
//添加数据
public static void InsertUser(Persion per = null)
{
//链接到表,数据库中存不存在表没关系,不存在mongodb会自动创建一个Collection
//("persion")Collection也叫表
var colls = db.GetCollection<Persion>("persion");
per = new Persion { _id = Guid.NewGuid().ToString(), Name = "ynland@126.com", age = 12 };
colls.InsertOne(per); }
//修改
public static void Updat()
{
//获取数据
var colls = db.GetCollection<Persion>("persion");
var model = colls.Find(c => c.Name =="ynland" ).FirstOrDefault();//筛选数据
//条件。相当于where后面的 Filte.Eq 相当于等号 Filter.Eq("字段",匹配值)
var filter = MongoDB.Driver.Builders<Persion>.Filter.Eq("Name", model.Name);
//修改的值,set("字段","修改后值") 注意 字段要和数据库中字段匹配,不匹配找不到会自动新建一个字段并赋值
var update = MongoDB.Driver.Builders<Persion>.Update.Set("age", "66");
// colls.UpdateOne(filter, update);//修改一条数据
UpdateResult res= colls.UpdateMany(filter, update);//多条修改 }
public static void DeleteInfo()
{
var colls = db.GetCollection<Persion>("persion");
colls.DeleteOne(c => c.age == 100);
}
//获取数据
public static void GetAllInfo()
{
//数据类型要一致才能不序列化
var t = db.GetCollection<Persion>("persion").Find(c => c.Name!=string.Empty);
List<Persion> list = t.ToList();
}
在修改的时候筛选,和set方便地方
筛选的条件Filter.XXX("字段名",“陪配值”)这样来筛选
在set的时候可以set().set().set().set().........这样来赋值
全部代码:
using System; using System.Collections.Generic; using System.Linq; using System.Web;using MongoDB.Driver; using MongoDB.Bson; using MongoDB.Driver.Linq; usingMongoDB.Bson.Serialization.Attributes; namespace MongoTest1 { public static classMongoUnitily { //数据库连接字符串 static string conn = "mongodb://127.0.0.1:27017"; //数据库名称 static string database = "appdb";//数据库名 static MongoUrl url = newMongoUrl(conn); static MongoClient ci = new MongoClient(url);//创建mongoClient static IMongoDatabase db = ci.GetDatabase(database);//获取数据库 //添加数据 public static void InsertUser(Persion per = null) { //链接到表,数据库中存不存在表没关系,不存在mongodb会自动创建一个Collection //("persion")Collection也叫表 var colls = db.GetCollection<Persion>("persion"); per = new Persion { _id = Guid.NewGuid().ToString(), Name = "ynland@126.com", age = 12 }; colls.InsertOne(per); } //修改 public static void Updat() { //获取数据 var colls = db.GetCollection<Persion>("persion"); var model = colls.Find(c => c.Name =="ynland" ).FirstOrDefault();//筛选数据 //条件。相当于where后面的 Filte.Eq 相当于等号 Filter.Eq("字段",匹配值) var filter = MongoDB.Driver.Builders<Persion>.Filter.AnyEq("Name", model.Name); //修改的值,set("字段","修改后值") 注意 字段要和数据库中字段匹配,不匹配找不到会自动新建一个字段并赋值 var update = MongoDB.Driver.Builders<Persion>.Update.Set("age", "66"); // colls.UpdateOne(filter, update);//修改一条数据 UpdateResult res= colls.UpdateMany(filter, update);//多条修改 } public static void DeleteInfo() { var colls = db.GetCollection<Persion>("persion"); colls.DeleteOne(c => c.age == 100); } //获取数据public static void GetAllInfo() { //数据类型要一致才能不序列化 var t = db.GetCollection<Persion>("persion").Find(c => c.Name!=string.Empty); List<Persion> list =t.ToList(); } } } public class Persion { //引用using MongoDB.Bson.Serialization.Attributes; [BsonId] public string _id; public string Name;public int age; public string Email; public string TableName { get{return "persion"; } } }
Mongodb 官网驱动2.2.4.26版本 增,删 改,查,mongodb2.2.4.26的更多相关文章
- Mongodb 官网驱动2.2.4.26版本 增,删 改,查
Mongodb是3.2.7版本 最近在学习mongodb数据库在网上找到的都不是2.X版本以下的,因为驱动从2.X以后修改了很多,以前不支持linq现2.X也支持了, Mongodb 启动服务就不说了 ...
- MongoDB官网驱动仓库封装
定义IMongoRepositoryBase接口 public interface IMongoRepositoryBase { /// <summary> ...
- Java操作MongoDB:连接&增&删&改&查
1.连接 ①方式一 MongoClientOptions.Builder builder = MongoClientOptions.builder(); //可以通过builder做各种详细配置 Mo ...
- MongoDB增 删 改 查
增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...
- Ubuntu14.04下Mongodb官网卸载部署步骤(图文详解)(博主推荐)
不多说,直接上干货! 前期博客 Ubuntu14.04下Mongodb官网安装部署步骤(图文详解)(博主推荐) https://docs.mongodb.com/manual/tutorial/ins ...
- Ubuntu16.04下Mongodb官网卸载部署步骤(图文详解)(博主推荐)
不多说,直接上干货! 前期博客 Ubuntu16.04下Mongodb官网安装部署步骤(图文详解)(博主推荐) https://docs.mongodb.com/manual/tutorial/ins ...
- MongoDB 红宝书-MongoDB官网使用指南
本文转载自Mongodb中文社区:http://www.mongoing.com/archives/27359 无论你是MongoDB的使用者.爱好者.初学者还是路人甲,有一个学习与进修的资源宝藏是千 ...
- 如何在官网下载java JDK的历史版本
如何在官网下载java JDK的历史版本 http://jingyan.baidu.com/article/9989c746064d46f648ecfe9a.html 如何在官网下载java JDK的 ...
- MongoDB 官网教程 下载 安装
官网:https://www.mongodb.com/ Doc:https://docs.mongodb.com/ Manual:https://docs.mongodb.com/manual/ 安装 ...
随机推荐
- es6系列-变量声明
es6系列所有文章都是阅读阮一峰老师的<ES6标准入门>(第2版)所做的读书笔记.方便日后查阅相关基础知识. git地址: https://github.com/rainnaZR/es6- ...
- 【原创】关于jquery实现格式化时间
//js格式化时间,参数jsonDate可以是后台数据 function jsonDateFormat(jsonDate) { try { var date = new Date(parseInt(j ...
- 【java】httpclient的使用之java代码内发送http请求
场景: 需要本项目发送HTTP请求到另一个项目中,处理完成返回值给本项目. 1.本项目引入架包 <!-- httpclient 后台发送http请求--> <dependency&g ...
- HDOJ1071
The area 拿到题的第一想法,又是一道水题,知道P1.P2.P3三点的坐标,就能够确定抛物线的公式.确定抛物线的公式就能够进行积分,然后就没有然后了.纯粹的数学题. #include< ...
- [UIDevice currentDevice]
获取iphone的系统信息使用[UIDevice currentDevice],信息例如以下: [[UIDevice currentDevice] systemName]:系统名称,如iPhone O ...
- 树状数组求最大值 (RMQ with Shifts)
代码: #include <iostream> #include <stdio.h> #include <string.h> #include <stdlib ...
- AsyncTask源代码解析
快要毕业了.近期在阿里巴巴校园招聘面试,一面过了,感觉挺轻松,可能是运气好.面试官感觉比我腼腆一些.我俩从android绕到了spring mvc 到数据库悲观锁 到linux 然后又会到了andro ...
- 为基于 x86 的 Android* 游戏选择合适的引擎
摘要 游戏开发者知道 Android 中蕴藏着巨大的机遇. 在 Google Play 商店的前 100 款应用中,约一半是游戏应用(在利润最高的前 100 款应用中.它们所占的比例超过 90%). ...
- 《Android Studio有用指南》7.1 AndroidStudio代码检查工具概述
本文节选自<Android Studio有用指南> 作者: 毕小朋 博客: http://blog.csdn.net/wirelessqa 眼下本书已上传到百度阅读, 在百度中搜索[Anr ...
- Markov Decision Processes
为了实现某篇论文中的算法,得先学习下马尔可夫决策过程~ 1. https://leonardoaraujosantos.gitbooks.io/artificial-inteligence/conte ...