源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-10-29 01:36 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:C#中使用1.7版本驱动操作MongoDB简单例子
[url=http://docs.mongodb.org/ecosystem/tutorial/getting-started-with-csharp-driver/]http://docs.mongodb.org/ecosystem/tutorial/getting-started-with-csharp-driver/[/url] 将一个引用添加到c#司机dll 右键单击 引用 文件夹在Visual Studio的解决方案 探险家和选择 添加 参考…… 。 导航到文件夹 c#驱动程序dll被安装并添加一个引用以下 dll:
[u]复制代码[/u] 代码如下:
    MongoDB.Bson.dll     MongoDB.Driver.dll
作为一种替代方法可以使用 NuGet 包管理器添加c# 驱动程序包来您的解决方案。 添加所需的 使用 语句 作为一个最低需要使用语句如下:
[u]复制代码[/u] 代码如下:
using MongoDB.Bson; using MongoDB.Driver;
此外,您会经常添加一个或多个使用 声明:
[u]复制代码[/u] 代码如下:
using MongoDB.Driver.Builders; using MongoDB.Driver.GridFS; using MongoDB.Driver.Linq;
还有其他名称空间,只会在特殊的需要 用例。 得到一个客户端对象的引用 最简单的方法获得一个客户对象的引用是使用 连接字符串:
[u]复制代码[/u] 代码如下:
var connectionString = "mongodb://localhost"; var client = new MongoClient(connectionString);
如果你想将客户端对象存储在一个全局变量。 MongoClient 是线程安全的。 对服务器对象的引用 要从客户端到服务器对象的引用对象,写 这样的:
[u]复制代码[/u] 代码如下:
var server = client.GetServer();
到一个数据库对象的引用 去到一个数据库对象的引用从服务器对象,写 这样的:
[u]复制代码[/u] 代码如下:
var database = server.GetDatabase("test"); // "test" is the name of the database
如果您使用多个数据库,调用 GetDatabase 再次为每个 您想要使用数据库。 BsonDocument 对象模型与您自己的域类 有两种方法可以处理集合:     使用 BsonDocument 对象模型     使用自己的域类 您将使用 BsonDocument 当数据对象模型 工作是如此的自由形式,它将是困难的或不可能的 定义的域类。 因为它是如此容易使用自己的域类 快速启动将假设你要这样做。 c#驱动程序 提供,他们可以处理您的域类:     有一个无参数的构造函数     定义公共读/写数据的字段或属性 存储在数据库中 这些需求在本质上是相同的。net的实施 XmlSerializer。 此外,如果您的域类将被用作根 文档必须包含一个 ID 字段或属性(通常是命名 ID 尽管你可以覆盖,如果必要)。 通常情况下, ID 将类型的 ObjectId ,但没有限制的类型 的成员。 考虑下面的类定义:
[u]复制代码[/u] 代码如下:
public class Entity {     public ObjectId Id { get; set; }     public string Name { get; set; } }
对一组对象的引用 你会得到一个包含引用集合 实体 文件是这样的:
[u]复制代码[/u] 代码如下:
// "entities" is the name of the collection var collection = database.GetCollection<Entity>("entities");
插入文档 插入一个 实体 :
[u]复制代码[/u] 代码如下:
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 值:
[u]复制代码[/u] 代码如下:
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 , 附近 , 东北 , 和 , 或 (和其他一些更多 专业的)。 保存一个文档 你可以保存更改现有的文档如下:
[u]复制代码[/u] 代码如下:
entity.Name = "Dick"; collection.Save(entity);
更新现有的文档 另一种选择 保存 是 更新 。 所不同的是, 保存 将整个文档发送回服务器,但是 更新 发的变化。 例如:
[u]复制代码[/u] 代码如下:
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 > 构建器轻松地构建更新 修饰符。 删除一个现有的文档 删除一个现有的文档集合你写:
[u]复制代码[/u] 代码如下:
var query = Query<Entity>.EQ(e => e.Id, id); collection.Remove(query);
你不需要调用连接或断开连接 c#司机有一个连接池使用连接到服务器 效率。 不需要电话 连接 或 断开 ; 让司机照顾连接(调用 连接 是无害的,但是打电话呢 断开 是不好的,因为它关闭 连接池中的连接)。 完整的示例程序
[u]复制代码[/u] 代码如下:
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)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部