我们有一组实体,其中包含需要对某些用户匿名的数据字段。我们有一个产品数据库,但产品的真实名称应该只对某些用户可见。其他用户应该只看到产品名称的“匿名”版本(匿名名称存储在产品表的另一个字段中)
我怎样才能轻松地使用实体框架来适应这一点。我们有一个映射器框架和一个服务层,我们的第一个方法是映射所有返回产品列表的方法的最终结果,但是我们有点失去了导航属性,我们希望避免复制完整的 EF 结构作为 DTO。
是否有一种在 EF 中注入基于用户的数据替换的简单方法?
我们有一组实体,其中包含需要对某些用户匿名的数据字段。我们有一个产品数据库,但产品的真实名称应该只对某些用户可见。其他用户应该只看到产品名称的“匿名”版本(匿名名称存储在产品表的另一个字段中)
我怎样才能轻松地使用实体框架来适应这一点。我们有一个映射器框架和一个服务层,我们的第一个方法是映射所有返回产品列表的方法的最终结果,但是我们有点失去了导航属性,我们希望避免复制完整的 EF 结构作为 DTO。
是否有一种在 EF 中注入基于用户的数据替换的简单方法?
就我个人而言,我会使用一个抽象层来做到这一点。例如存储库模式。
public virtual TPoco Get(Expression<Func<TPoco, bool>> predicate) {
//This routine would execute the normal find or first as you like...eg
var resultEntity = Context.Set<TPoco>().FirstOrDefault(predicate);
// but before returning.
var anonResult = Blender<poco>(TPoco resultEntity); // this does the anon massaging
return AnonResult;
}