如何解决基于条件运算符的C#构建表达式树,用于MongoDB过滤器
我正在基于条件运算符构建表达式树,但无法使用MongoDb函数使用所需的过滤器。
这是我的职能
header { color: blue; background: yellow; font-size: 20px; }
我的问题是如何使用条件运算符构建表达式树?
public Task<long> GetUserCountAsync(string tenantId,CancellationToken cancellationToken = default)
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfdisposed();
Expression<Func<TUser,bool>> filter = t => string.IsNullOrWhiteSpace(tenantId) ? t.TenantId != null : t.TenantId == tenantId;
return await mongoCollection.CountDocumentsAsync(filter);
}
解决方法
问题在于数据库不支持您要构建的表达式。
更改方法。不要在表达式本身中包含条件
//...
Expression<Func<TUser,bool>> filter = t => t.TenantId == tenantId;
if(string.IsNullOrWhiteSpace(tenantId))
filter = t => t.TenantId != null;
//...
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。