C#中使用1.7版本驱动操作MongoDB简单例子

代码如下:

//创建数据库链接
//在1.7的版本驱动中这样写是会报 MongoServer方法已过时的
//MongoServer server =  MongoDB.Driver.MongoServer.Create(strconn);

//带有用户名,密码的如下写法,不带的则直接ip+端口就可以
const string connectionString = "mongodb://city:liyang@192.168.1.211:27017";
//得到一个客户端对象的引用                    GetServer()对服务器对象的引用          
var Server = new MongoClient(connectionString).GetServer();
//到一个数据库对象的引用
var client = Server.GetDatabase("City");
//对一组对象的引用
var collection = client.GetCollection<citys>("citys");

//插入一个 实体
for (int i = 0; i < dt.Rows.Count; i++)
{
    collection.Insert(new citys
    {
        province = dt.Rows[i][0].ToString(),
        city = dt.Rows[i][1].ToString(),
        county = dt.Rows[i][2].ToString(),
        areacode = "0" + dt.Rows[i][3].ToString(),
        postalcode = dt.Rows[i][3].ToString()
    });
}

以下是git上的帮助文档  地址是:http://docs.mongodb.org/ecosystem/tutorial/getting-started-with-csharp-driver/
将一个引用添加到c#司机dll

右键单击 引用 文件夹在Visual Studio的解决方案 探险家和选择 添加 参考…… 。 导航到文件夹 c#驱动程序dll被安装并添加一个引用以下 dll:

代码如下:

MongoDB.Bson.dll
    MongoDB.Driver.dll

作为一种替代方法可以使用 NuGet 包管理器添加c# 驱动程序包来您的解决方案。
添加所需的 使用 语句

作为一个最低需要使用语句如下:

代码如下:

using MongoDB.Bson;
using MongoDB.Driver;

此外,您会经常添加一个或多个使用 声明:

代码如下:

using MongoDB.Driver.Builders;
using MongoDB.Driver.GridFS;
using MongoDB.Driver.Linq;

还有其他名称空间,只会在特殊的需要 用例。
得到一个客户端对象的引用

最简单的方法获得一个客户对象的引用是使用 连接字符串:

代码如下:

var connectionString = "mongodb://localhost";
var client = new MongoClient(connectionString);

如果你想将客户端对象存储在一个全局变量。 MongoClient 是线程安全的。
对服务器对象的引用

要从客户端到服务器对象的引用对象,写 这样的:

代码如下:

var server = client.GetServer();

到一个数据库对象的引用

去到一个数据库对象的引用从服务器对象,写 这样的:

代码如下:

var database = server.GetDatabase("test"); // "test" is the name of the database

如果您使用多个数据库,调用 GetDatabase 再次为每个 您想要使用数据库。
BsonDocument 对象模型与您自己的域类

有两种方法可以处理集合:

使用 BsonDocument 对象模型
    使用自己的域类

您将使用 BsonDocument 当数据对象模型 工作是如此的自由形式,它将是困难的或不可能的 定义的域类。

因为它是如此容易使用自己的域类 快速启动将假设你要这样做。 c#驱动程序 提供,他们可以处理您的域类:

有一个无参数的构造函数
    定义公共读/写数据的字段或属性 存储在数据库中

这些需求在本质上是相同的。net的实施 XmlSerializer。

此外,如果您的域类将被用作根 文档必须包含一个 ID 字段或属性(通常是命名 ID 尽管你可以覆盖,如果必要)。 通常情况下, ID 将类型的 ObjectId ,但没有限制的类型 的成员。

考虑下面的类定义:

代码如下:

public class Entity
{
    public ObjectId Id { get; set; }

public string Name { get; set; }
}

对一组对象的引用

你会得到一个包含引用集合 实体 文件是这样的:

代码如下:

// "entities" is the name of the collection
var collection = database.GetCollection<Entity>("entities");

插入文档

插入一个 实体 :

代码如下:

var entity = new Entity { Name = "Tom" };
collection.Insert(entity);
var id = entity.Id; // Insert will set the Id if necessary (as it was in this example)

找到一个现有的文档

在这个示例中,我们将读回 实体 假设我们知道 ID 值:

代码如下:

var query = Query<Entity>.EQ(e => e.Id, id);
var entity = collection.FindOne(query);

查询<单位> .EQ 使用 查询< T > 构建器类来构建 查询。 lambda表达式 E = > e.Id 是翻译 _ID 。 这是 字段的名称存储在数据库中。

请注意

通常的名称字段在数据库中是完全相同的 正如它的名字域类中的字段或属性,但是 ID 是一个例外,映射到吗 _ID 在数据库中。

其他查询操作符包括: GT , 一种 , 在 , LT , LTE , 附近 , 东北 , 和 , 或 (和其他一些更多 专业的)。
保存一个文档

你可以保存更改现有的文档如下:

代码如下:

entity.Name = "Dick";
collection.Save(entity);

更新现有的文档

另一种选择 保存 是 更新 。 所不同的是, 保存 将整个文档发送回服务器,但是 更新 发的变化。 例如:

代码如下:

var query = Query<Entity>.EQ(e => e.Id, id);
var update = Update<Entity>.Set(e => e.Name, "Harry"); // update modifiers
collection.Update(query, update);

下面的例子使用了 更新< T > 构建器轻松地构建更新 修饰符。
删除一个现有的文档

删除一个现有的文档集合你写:

代码如下:

var query = Query<Entity>.EQ(e => e.Id, id);
collection.Remove(query);

你不需要调用连接或断开连接

c#司机有一个连接池使用连接到服务器 效率。 不需要电话 连接 或 断开 ; 让司机照顾连接(调用 连接 是无害的,但是打电话呢 断开 是不好的,因为它关闭 连接池中的连接)。
完整的示例程序

代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using MongoDB.Bson;
using MongoDB.Driver;
using MongoDB.Driver.Builders;

namespace ConsoleApplication1
{
    public class Entity
    {
        public ObjectId Id { get; set; }
        public string Name { get; set; }
    }

class Program
    {
        static void Main(string[] args)
        {
            var connectionString = "mongodb://localhost";
            var client = new MongoClient(connectionString);
            var server = client.GetServer();
            var database = server.GetDatabase("test");
            var collection = database.GetCollection<Entity>("entities");

var entity = new Entity { Name = "Tom" };
            collection.Insert(entity);
            var id = entity.Id;

var query = Query<Entity>.EQ(e => e.Id, id);
            entity = collection.FindOne(query);

entity.Name = "Dick";
            collection.Save(entity);

var update = Update<Entity>.Set(e => e.Name, "Harry");
            collection.Update(query, update);

collection.Remove(query);
        }
    }
}

(0)

相关推荐

  • C#如何检测操作系统版本

    本文实例为大家分享了C#检测操作系统版本的方法,供大家参考,具体内容如下 我们通过System.Environment.OSVersion.Version获得操作系统的版本号,然后再根据版本号进行判断操作系统是什么版本. Version 类的属性 参考于:https://msdn.microsoft.com/zh-cn/library/windows/desktop/ms724834(v=vs.85).aspx 注意:在msdn官方文档有说明 → OSVersion 属性报告两个相同的版本号 (

  • 磁盘配额的wmi版本(C#)

    using System;  using System.Management;  namespace DiskQuota  {       /// <summary>       /// Class1 的摘要说明.       /// </summary>       class Class1       {           /// <summary>           /// 应用程序的主入口点.           /// </summary> 

  • C# 获取程序集版本、文件版本

    一.获取程序集版本 程序代码 复制代码 代码如下: label版本.Text = System.Reflection.Assembly.GetExecutingAssembly().GetName().Version.ToString(); 二.获取文件版本 程序代码 复制代码 代码如下: using System.Diagnostics; FileVersionInfo myFileVersion = FileVersionInfo.GetVersionInfo (System.Windows

  • C#获取系统版本信息方法

    直接贴代码: 复制代码 代码如下: public class OSInfoMation { public static string OSBit() { try { ConnectionOptions oConn = new ConnectionOptions(); System.Management.ManagementScope managementScope = new System.Management.ManagementScope("\\\\localhost", oCon

  • asp.net(c#)程序版本升级更新的实现代码

    直接上代码: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Text; using System.Reflection; using System.IO; using System.Net; using System.Xml; namespace Update {     /// <summary>     /// 更新完成触发的事件     /// </summary>     pu

  • C#自动判断Excel版本使用不同的连接字符串

    用OLEDB通过设置连接字符串可以像读取sqlserver一样将excel中的数据读取出来,但是excel2003和excel2007/2010的连接字符串是不同的. /// <summary> /// 把数据从Excel装载到DataTable /// </summary> /// <param name="pathName">带路径的Excel文件名</param> /// <param name="sheetName

  • 验证本机的excel版本的C#代码

    复制代码 代码如下: /// <summary> /// 安装的excel的版本,0为没有安装,大于1说明安装了多个. /// </summary> /// <returns></returns> public static List<string> ExcelVersion() { List<string> list = new List<string>(); List<string> lisemp = ne

  • C#连接Excel2003和Excel2007以上版本做数据库的连接字符串

    复制代码 代码如下: string fileExt = Path.GetExtension(excelPath); string conn = ""; if (fileExt == ".xls") { conn = "Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source =" + excelPath + ";Extended Properties='Excel 8.0;HDR=Yes;IMEX

  • C#调用C++版本dll时的类型转换需要注意的问题小结

    C#对于C++的dll引用时,经常会遇到类型转换和struct的转换 1. C++ 里的Char类型是1 个字节,c#里的Char是两个字节,不可以对应使用:可使用c#里的byte对应 2. structType temp = (structType)Marshal.PtrToStructure(IntPtr, typeof(structType));说明:此方式转换只针对包含c++基本类型的结构体,如果包含指针数组的结构体,使用泛型函数比较方便. 3. [StructLayoutAttribu

  • C#实现判断操作系统是否为Win8以上版本

    1.利用C#获取OS的版本号 (1) 原理说明 Environment类的OSVersion属性是一个OperatingSystem类型的对象,OperatingSystem类表示有关操作系统的信息,如版本和平台标识符.OperatingSystem类的Version属性,描述了操作系统的主版本号.次版本号.内部版本号和修正版本号,所以可以使用Environment.OSVersion.Version来获取操作系统的版本信息. (2) 具体代码 using System; namespace G

随机推荐