MongoDB C# 驱动程序 - 忽略绑定字段
- 作者: 别人都叫我符号君
- 来源: 51数据库
- 2022-10-28
问题描述
使用 MongoDB 和 C# 使用 FindOne() 时,是否可以忽略对象中未找到的字段?
When using a FindOne() using MongoDB and C#, is there a way to ignore fields not found in the object?
EG,示例模型.
public class UserModel
{
public ObjectId id { get; set; }
public string Email { get; set; }
}
现在我们也在 MongoDB 集合中存储了一个密码,但不想将其绑定到上面的 out 对象.当我们像这样执行 Get 时,
Now we also store a password in the MongoDB collection, but do not want to bind it to out object above. When we do a Get like so,
var query = Query<UserModel>.EQ(e => e.Email, model.Email); var entity = usersCollection.FindOne(query);
我们收到以下错误
Element 'Password' does not match any field or property of class
无论如何要告诉 Mongo 忽略它无法与模型匹配的字段?
Is there anyway to tell Mongo to ignore fields it cant match with the models?
推荐答案
是的.只需使用 BsonIgnoreExtraElements 属性装饰您的 UserModel 类:
Yes. Just decorate your UserModel class with the BsonIgnoreExtraElements attribute:
[BsonIgnoreExtraElements]
public class UserModel
{
public ObjectId id { get; set; }
public string Email { get; set; }
}
顾名思义,驱动程序会忽略任何额外的字段而不是抛出异常.更多信息在这里 - 忽略额外元素.
As the name suggests, the driver would ignore any extra fields instead of throwing an exception. More information here - Ignoring Extra Elements.
- C#通过fleck实现wss协议的WebSocket多人Web实时聊天(附源码)
- 团队城市未满足要求:MSBuildTools12.0_x86_Path 存在
- 使用 MSBuild.exe 在发布模式下构建 C# 解决方案
- 当我发布 Web 应用程序时,AfterPublish 脚本不运行
- 构建时 T4 转换的产品仅在下一个构建中使用
- ASP.NET Core Application (.NET Framework) for Windows x64 only error in project.assets.json
- 新的 .csproj 格式 - 如何将整个目录指定为“链接文件"到子目录?
- 如何将条件编译符号(DefineConstants)传递给 msbuild
- MSBuild 支持 Visual Studio 2017 RTM 中的 T4 模板
- NuGet 包还原找不到包,没有源
