Docs 菜单

新增功能

了解以下版本中的新功能:

3.2驱动程序版本包括以下新功能:

  • 添加了新的 ObjectSerializerAllowedTypesConvention 约定,允许指定对象序列化器可以对哪些类型进行序列化和反序列化。要学习;了解有关约定的更多信息,请参阅 约定指南。

  • EnumRepresentationConvention 类添加一个新的构造函数,该构造函数允许您使用 topLevelOnly 参数来指定该约定是仅适用于枚举属性还是适用于包含枚举集合的所有属性。

    您可以使用 new 构造函数实例化 EnumRepresentationConvention 类,如以下示例所示:

    EnumRepresentationConvention(BsonType representation, bool topLevelOnly);
  • 优化客户端投影,仅从服务器检索必填字段,而不是检索所有字段然后进行过滤。

  • 添加以下类以支持Atlas Vector Search中的二进制向量表示:

    • BinaryVectorFloat32

    • BinaryVectorInt8

    • BinaryVectorPackedBit

    要学习;了解有关使用.NET/ C#驱动程序的Atlas Vector Search 的更多信息,请参阅Atlas Vector Search指南。

3.1驱动程序版本包括以下新功能:

  • System.Collections.Immutable命名空间中的不可变集合添加新的默认序列化器。驾驶员现在可以序列化 ImmutableArray 对象,并且其他不可变集合的序列化内存效率更高。

  • 使用 equals操作符符的Atlas Search构建者添加对令牌字段类型和大量字段表达式的支持。 要学习;了解有关将Atlas Search与.NET/ C#驱动程序结合使用的更多信息,请参阅Atlas Search。

  • 在Atlas Search中添加对顺序分页的支持。

  • 新增对少于 3 部分的有效 SRV 主机名的支持。

  • 在MongoDB查询API筛选器中添加对 ExistsIsMissingIsNullOrMissing 方法的支持。

  • 添加对精确最近邻 (ENN)向量搜索的支持。 要学习;了解有关新奥向量搜索的更多信息,请参阅Atlas Search文档中的运行向量搜索查询。

  • 添加了对要传递给更新命令的 sort 选项的支持。要学习;了解有关更新命令与.NET/ C#驱动程序结合使用的更多信息,请参阅更新一个更新多个

有关此发布的更多信息,请参阅 v3.1 发布说明。

警告

v 3.0 中的重大更改

v 3.0驾驶员包含重大更改。有关更多信息,请参阅版本3.0 重大更改。

3.0驱动程序版本包括以下新功能:

  • 添加 MongoClientSettings.TranslationOptions 连接选项,该选项指定用于将 LINQ 查询转换为 Query API的选项。有关详细信息,请参阅连接选项。

  • 添加对 Half 类型的支持,该类型表示半精度浮点数。此类型在.NET 5 及更高版本中可用。要学习;了解有关Half 类型的更多信息,请参阅 MSDN 上的“半结构体API ”参考页面。

  • IMongoClient 接口继承 IDisposable 接口。因此,实现IMongoClient 接口的 MongoClient 类和其他类都包含 Dispose() 方法,该方法可对客户端进行处置。此方法不会释放根本的集群以及与MongoDB 服务器的连接。 要销毁集群和连接,请调用 ClusterRegistry.UnregisterAndDisposeCluster() 方法。IDisposable 接口的实施是实验性的。

    要学习;了解有关IDisposable 接口和使用Dispose() 方法的详情,请参阅 MSDN 上的“处置模式”。

  • 新增对 DateOnly 类型的支持,该类型表示不带时间组件的日期值。此类型在.NET 6 及更高版本中可用。要学习;了解有关DateOnly 类型的更多信息,请参阅 DateOnly 结构体。MSDN 上的API参考页面。

  • 新增对 TimeOnly 类型的支持,该类型表示不带日期组件的时间值。此类型在.NET 6 及更高版本中可用。要学习;了解有关TimeOnly 类型的更多信息,请参阅 TimeOnly 结构体。MSDN 上的API参考页面。

  • 添加在将 Find() 方法、Select() 方法或 Project()聚合阶段与 LINQ 3提供商一起使用时对隐式客户端投影的支持。在以前版本的驾驶员中,只有在调用 ToEnumerable()AsEnumerable() 方法后,才能使用 LINQ 3提供商执行客户端投影。

    要学习;了解如何为驾驶员方法启用和使用客户端投影,请选择相应的标签页:

    // Enable client-side projection
    var findOptions = new FindOptions();
    findOptions.TranslationOptions = new ExpressionTranslationOptions
    {
    EnableClientSideProjections = true
    };
    var find = collection
    .Find(doc => doc.Id == 1, findOptions);
    .Project(doc => new { R = MyFunction(doc.Name) });
    // Enable client-side projection
    var aggregateOptions = new AggregateOptions();
    aggregateOptions.TranslationOptions = new ExpressionTranslationOptions
    {
    EnableClientSideProjections = true
    };
    var queryable = collection
    .AsQueryable(aggregateOptions)
    .Where(doc => doc.Id == 1)
    .Select(doc => new { R = MyFunction(doc.Name) });
    // Enable client-side projection
    var aggregateOptions = new AggregateOptions();
    aggregateOptions.TranslationOptions = new ExpressionTranslationOptions
    {
    EnableClientSideProjections = true
    };
    var aggregate = collection
    .Aggregate(aggregateOptions)
    .Project(doc => new { R = MyFunction(doc.Name) });

    提示

    MongoClientSettings

    要为客户端上的所有查询启用客户端客户端投影,请设立MongoClientSettings对象的 TranslationOptions属性,如以下示例所示:

    clientSettings.TranslationOptions = new ExpressionTranslationOptions
    {
    EnableClientSideProjections = true
    };

    要学习;了解有关将聚合管道与.NET/ C#驱动程序结合使用的更多信息,请参阅聚合。

  • 为批量写入操作添加 MongoClient API 。要学习;了解有关批量写入操作的更多信息,请参阅批量写入操作。

有关此发布的更多信息,请参阅 v3.0 发布说明。

2.30驾驶员不会引入新功能或错误修复。其目的是通过将 v 3.0 中删除的公共 API 标记为已过时,以便轻松迁移到.NET/ C#驱动程序v 3 .x。

2.29驾驶员发布增加了对MongoDB Server 8.0版本的支持,并包含以下新功能:

  • 新增支持v 2的Queryable Encryption范围协议的支持。

  • 添加对Queryable Encryption范围索引的支持。 有关Queryable Encryption的更多信息,请参阅MongoDB Server手册中的Queryable Encryption

有关此发布的更多信息,请参阅 v2.29 发布说明。

警告

v 2.28中潜在的重大更改

  • 所有.NET/ C#驱动程序组件都有强命名。 如果应用程序具有引用多个.NET/ C#驱动程序版本的依赖项,则必须创建绑定重定向来管理这些依赖项。 有关更多信息,请参阅版本 2.28.0重大更改。

2.28驱动程序版本包括以下新功能:

  • 添加了对涉及Nullable<T>的其他数字转换的支持。

  • 添加了在使用 KMIP 进行CSFLE 或Queryable Encryption时对delegated选项的支持。

有关此发布的更多信息,请参阅 v2.28 发布说明。

2.27驱动程序版本包括以下新功能:

  • 新增支持$sample聚合操作符的支持。

  • 为 LINQ 3中的序列化器实现Equals()方法。

  • 确保读关注和写入关注不会应用于Atlas Search索引助手命令,以避免错误。

  • 使用 MONGODB-OIDC身份验证机制时,禁止在 authMechanismProperties 连接string值中使用逗号字符。

  • 修复了一个转换错误,该错误在涉及不同大小的数字的序列化过程中导致错误。

  • 新增对使用libdl.so.2库的Linux发行版的支持。

有关此发布的更多信息,请参阅 v2.27 发布说明。

2.26驱动程序版本包括以下新功能:

  • 添加了对在Select()Project()聚合阶段使用SelectMany()聚合方法的支持。

  • 在 LINQ 查询中添加了对Dictionary.ContainsValue()调用的支持。

  • 添加了对混合类型string连接的支持。

  • 支持在libmongocrypt绑定中使用原生crypto

  • 添加了对MemoryReadOnlyMemory结构序列化的支持。

  • 添加了使用MONGODB-OIDC身份验证机制时对GCP身份提供商的支持。 要学习;了解更多信息,请参阅 企业身份验证机制指南中的GCP IMDS

  • 实现了 NuGet 包的签名。

  • 尽可能对其他mongos实例实施读取和写入重试。

2.25驱动程序版本包括以下新功能:

  • 添加了对MONGODB-OIDC身份验证机制和 Azure 身份提供者自动获取令牌的支持。

  • BsonClassMapSerializer找不到匹配的创建者时报告的错误消息中添加了类名称。

  • 添加了LoggedStages字段以显示执行 LINQ查询后执行的MQL 。

  • 添加了对通过使用srvServiceName连接选项以自定义服务名称覆盖"mongodb"服务名称的支持。

  • 改进批量写入操作的行为,以防止多次枚举请求参数。

2.24驱动程序版本包括以下新功能:

  • 添加了 IMongoCollection.DistinctMany() 方法。

  • 添加了对$dateFromString聚合表达式的最新可选参数的支持。

  • $search聚合阶段添加了对按分数排序的支持。

  • $vectorSearch聚合阶段添加了VectorSearchScore构建器。

  • 在 Atlas Search 中添加了对$in操作符的支持。

  • 为 LINQ 查询添加了Mql.Exists()Mql.IsMissing()Mql.IsNullOrMissing()方法。

  • 在 LINQ 查询中添加了对IComparable.CompareTo()方法的支持。

  • 添加了对AsQueryable()方法嵌套调用的支持,以支持MongoDB 实体框架核心提供程序的 LINQ 查询。

  • 添加了对 TLS 1.3的支持。

  • libmongocrypt包版本更新到1.8.2 。

  • 修复了较新 Linux 发行版上 Kerberos ( libgssapi ) 中的段错误。

  • 修复了一个 GridFS 错误;在该错误中,如果同时上传了具有相同 ID 的较大文件,则下载文件会导致错误。

  • 现在,读取和写入操作都可重试ExceededTimeLimit服务器错误。

  • 当在函数即服务 (FaaS) 环境(例如 Amazon Web Services Lambda)中运行时,驱动程序现在使用轮询监控机制。

  • 为了提高MongoDB Atlas Serverless 兼容性,驾驶员现在使用 OP_MSG 进行身份验证(如果服务器支持)。

2.23驱动程序版本包括以下新功能:

  • 对 LINQ 3集成的改进和错误修复。

  • 添加了对聚合按位运算符的支持。

  • 添加了对 MongoDB 时间序列集合中$out操作符的支持。

  • 添加 了 ChangeStreamSplitLargeEvent 处理大于16 MB 的变更流事件。

2.22驱动程序版本包括以下新功能:

  • 对 LINQ 3集成的改进和错误修复。

  • 添加了对$set$vectorSearch聚合阶段的支持。

  • 为Atlas Search添加了同义词支持。

  • 使用加密时减少内存分配。

  • 添加了服务器发现和监控(SDAM) 事件的日志消息。 有关这些事件的更多信息,请参阅 MongoDB SDAM 日志记录和监控规范。