问题描述
我使用的是规范模式+存储库模式,它们与Entity Framework配合得很好,但是现在我切换到Nosql DynamoDb
我尝试将Expression映射到ScanCondition(),但是失败
这是我的存储库方法
public abstract class DynamoDbRepository
: IAsyncRepository<ReturnModel>{
public virtual async Task<IReadOnlyList<ReturnModel>> ListAsync(
ISpecification<ReturnModel> spec)
{
//difficult to convert from Expression to Object
new ScanCondition(...,....,....)
}
}
这是我的规范
public class ProductSpecification : Specification<Product>
{
public ProductSpecification(
int skip,int take,string categogryId = null) : base()
{
if (categogryId != null)
{
Query
.Where(x => (categogryId != null && x.CategoryId == categogryId));
}
Query.Skip(skip).Take(take);
}
public void BuildQuery(Expression<Func<Product,bool>> func)
{
Query.Where(func);
}
}
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)