MongoDB C# 驱动程序 - 忽略绑定字段

MongoDB C# Driver - Ignore fields on binding(MongoDB C# 驱动程序 - 忽略绑定字段)
本文介绍了MongoDB C# 驱动程序 - 忽略绑定字段的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

使用 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.

这篇关于MongoDB C# 驱动程序 - 忽略绑定字段的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

LINQ to SQL query using quot;NOT INquot;(使用“NOT IN的 LINQ to SQL 查询)
How to do a full outer join in Linq?(如何在 Linq 中进行完整的外部联接?)
LINQ to SQL Web Application Best Practices(LINQ to SQL Web 应用程序最佳实践)
How do I group data in an ASP.NET MVC View?(如何在 ASP.NET MVC 视图中对数据进行分组?)
how to update the multiple rows at a time using linq to sql?(如何使用 linq to sql 一次更新多行?)
how to recognize similar words with difference in spelling(如何识别拼写不同的相似词)