LINQ生成子查询的简单顺序
我无法理解为什么SQL输出具有我在LINQ中编写的简单查询的子查询。 这是我的代码:
var list = db.User.Where(u => u.Name == somename).OrderBy(u => u.IdUser).ToList();
somename是我在执行时传递的参数。
输出SQL是:
SELECT Project1.IdUser, Project1.Name FROM (SELECT Extent1.IdUser, Extent1.Name FROM user AS Extent1 WHERE Extent1.Name = 'John' /* @p__linq__0 */) AS Project1 ORDER BY Project1.IdUser ASC
输出真的应该有一个简单的子查询吗?
我也试过了
var list = db.User.Where(u => u.Name.Equals(somename)).OrderBy(u => u.IdUser).ToList();
它产生与上面相同的输出。
如果我硬编码参数,如:
var list = db.User.Where(u => u.Name == "John").OrderBy(u => u.IdUser).ToList();
它按预期工作,仅生成
SELECT Extent1.IdUser, Extent1.Name FROM user AS Extent1 WHERE 'John' /* @gp1 */ = Extent1.Name ORDER BY Extent1.IdUser ASC
我正在使用的一些东西:
- EntityFramework 5,.NET 4.5
- SQL Server 2012
- Glimpse(使用MiniProfiler)查看生成的SQL
我不是LINQ专家,所以我在这里缺少什么?
与其他人一样,查询会产生与您相同的执行计划。 entity framework(和LINQ to Entites)可以帮助您避免编写SQL并在某种程度上打扰SQL。 在正常情况下,您不关心生成SQL,也不“调试”它。 你只关心LINQ查询是否正确。 entity framework(应该)将其转换为正确的(有时甚至是预期的)SQL(再次,执行计划很重要)。
我不是说你出于性能原因不应该看SQL(或者更好地说出该查询的执行计划)。 但是, 在确定性能问题后 ,应该这样做。 你应该首先尝试简单地编写查询,这是成功的方法。 当然,如果你知道SQL,你知道这个集合世界与对象世界不同 – 你可以在LINQ中轻松编写相当普通的查询(感谢对象世界),但这最终会因为“令人讨厌的SQL(设置世界)而因为”世界之间的不匹配。