繁体   English   中英

实体框架将where子句附加到SqlQuery调用

[英]Entity Framework append where clause to SqlQuery call

我有以下原始查询通过Entity Framework通过DbSet上的SqlQuery调用DbSet

public IEnumerable<TEntity> GetComplicatedData<TEntity>()
{
    return database
        .Set<TEntity>()
        .SqlQuery("SELECT * FROM <Complicated Query Here>");
}

...

var count = GetComplicatedData<Item>()
    .Where(f => f.OwnerID == 5)
    .Count();

这可以工作,但是由于SqlQuery立即执行而没有应用Where的事实,因此非常慢。

有没有什么方法可以在WhereSqlQuery调用到服务器端?

本质上,我希望Entity Framework生成如下存储查询:

SELECT 
    <Columns> 
FROM 
(
    SELECT * FROM <Complicated Query Here>
) a
WHERE a.OwnerID = 5

或者,是否有一种方法可以将我的where表达式转换为可以手动附加的查询(aka,而无需手动编写SQL查询,where子句并不总是那么简单)?

这不能使用LINQ方法完成,因为“原始”查询的类型为DbRawSqlQuery<TElement> ,该类型缺少使用Where来“组成”动态查询所需的支持。

如果您希望对项目进行计数,则可以通过以下条件解决此问题:

public int CountComplicatedData<TEntity>(Func<TEntity,bool> condition) {
    return database
        .Set<TEntity>()
        .SqlQuery("SELECT * FROM <Complicated Query Here>")
        .Count(condition);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM