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 = };
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", "");
// 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 == );
}
//获取数据
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;
using MongoDB.Bson.Serialization.Attributes; namespace MongoTest1
{
public static class MongoUnitily
{
//数据库连接字符串
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 = };
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", "");
// 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 == );
}
//获取数据
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版本 增,删 改,查的更多相关文章

  1. Mongodb 官网驱动2.2.4.26版本 增,删 改,查,mongodb2.2.4.26

    Mongodb是3.2.7版本 最近在学习mongodb数据库在网上找到的都不是2.X版本以下的,因为驱动从2.X以后修改了很多,以前不支持linq现2.X也支持了, Mongodb 启动服务就不说了 ...

  2. MongoDB官网驱动仓库封装

    定义IMongoRepositoryBase接口 public interface IMongoRepositoryBase     {         /// <summary>     ...

  3. Java操作MongoDB:连接&增&删&改&查

    1.连接 ①方式一 MongoClientOptions.Builder builder = MongoClientOptions.builder(); //可以通过builder做各种详细配置 Mo ...

  4. MongoDB增 删 改 查

    增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...

  5. Ubuntu14.04下Mongodb官网卸载部署步骤(图文详解)(博主推荐)

    不多说,直接上干货! 前期博客 Ubuntu14.04下Mongodb官网安装部署步骤(图文详解)(博主推荐) https://docs.mongodb.com/manual/tutorial/ins ...

  6. Ubuntu16.04下Mongodb官网卸载部署步骤(图文详解)(博主推荐)

    不多说,直接上干货! 前期博客 Ubuntu16.04下Mongodb官网安装部署步骤(图文详解)(博主推荐) https://docs.mongodb.com/manual/tutorial/ins ...

  7. MongoDB 红宝书-MongoDB官网使用指南

    本文转载自Mongodb中文社区:http://www.mongoing.com/archives/27359 无论你是MongoDB的使用者.爱好者.初学者还是路人甲,有一个学习与进修的资源宝藏是千 ...

  8. 如何在官网下载java JDK的历史版本

    如何在官网下载java JDK的历史版本 http://jingyan.baidu.com/article/9989c746064d46f648ecfe9a.html 如何在官网下载java JDK的 ...

  9. MongoDB 官网教程 下载 安装

    官网:https://www.mongodb.com/ Doc:https://docs.mongodb.com/ Manual:https://docs.mongodb.com/manual/ 安装 ...

随机推荐

  1. 洛谷P1438 无聊的数列 [zkw线段树]

    题目传送门 无聊的数列 题目背景 无聊的YYB总喜欢搞出一些正常人无法搞出的东西.有一天,无聊的YYB想出了一道无聊的题:无聊的数列...(K峰:这题不是傻X题吗) 题目描述 维护一个数列{a[i]} ...

  2. 【LeetCode two_pointer】11. Container With Most Water

    Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, ai).  ...

  3. PHP视频教程 字符串处理函数(三)

    字符串替换函数: str_replace() 替换字符串或数组元素,区分大小,第四个参数可选用于统计替换次数. str_ireplace() 不区分大小写替换 字符串函数比较 strcmp()比较字符 ...

  4. bzoj 4094: [Usaco2013 Dec]Optimal Milking

    4094: [Usaco2013 Dec]Optimal Milking Description Farmer John最近购买了N(1 <= N <= 40000)台挤奶机,编号为1 . ...

  5. YanghuiTriangle

    Demand 1 用实现循环队列 2 参考PPT用循环队列打印杨辉三角 3 用JDB或IDEA单步跟踪排队情况,画出队列变化图,包含自己的学号信息 4 把代码推送到代码托管平台 5 把完成过程写一篇博 ...

  6. Linux知识(2)----中文输入法安装

    Ubantu14.04在English的环境下,没有中文输入法,自带的ibus不完整.现在基于ibus框架,有几个比较好用的输入法,如sunpingyin和google pinying,还有五笔的输入 ...

  7. jQuery使用一知半解

    jQuery是目前使用最广泛的javascript函数库.据统计,全世界排名前100万的网站,有46%使用jQuery,远远超过其他库.微软公司甚至把jQuery作为他们的官方库.对于网页开发者来说, ...

  8. Sencha Touch开发环境搭建及ext插件Spket安装

    第一步:JAVA SDK(JDK)的安装 以去问百度下载JDK,也可以到官方下载JDK. 下载地址: http://www.oracle.com/technetwork/java/javase/dow ...

  9. Delphi插件创建、调试与使用应用程序扩展

    Delphi插件创建.调试与使用应用程序扩展 翻译 : MiracleZ  有没有使用过Adobe Photoshop?如果用过,你就会对插件的概念比较熟悉.对外行人来说,插件仅仅是从外部提供给应用程 ...

  10. set bin 集合

    set: create table rr(zz char(4));create table test5 (rr set('美丽','态度好','温柔','善良'));insert into test5 ...