Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/334.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# linq到EF,如何使用';top`方法_C#_Sql_Linq_Entity Framework_Linq To Entities - Fatal编程技术网

C# linq到EF,如何使用';top`方法

C# linq到EF,如何使用';top`方法,c#,sql,linq,entity-framework,linq-to-entities,C#,Sql,Linq,Entity Framework,Linq To Entities,我想使用linq to Entities将top记录按降序列Value1排序 我知道我可以这样写: MyCollection.OrderByDescending(item=>item.Value1.FirstOrDefault() 但是如何使用下面的方法Top System.Data.Objects.ObjectQuery.Top(字符串,参数System.Data.Objects.ObjectParameter[])请查看MSDN以获取示例 编辑:这个答案是在问题特别是关于LINQ到SQL的时

我想使用linq to Entities将
top
记录按降序列
Value1
排序

我知道我可以这样写:

MyCollection.OrderByDescending(item=>item.Value1.FirstOrDefault()

但是如何使用下面的方法
Top


System.Data.Objects.ObjectQuery.Top(字符串,参数System.Data.Objects.ObjectParameter[])

请查看MSDN以获取示例


编辑:这个答案是在问题特别是关于LINQ到SQL的时候写的

据我所知,
System.Data.Objects
用于实体框架,而不是LINQ-to-SQL,但要在LINQ-to-SQL甚至LINQ-to-Objects中找到前N个值,通常只需使用
Take

var query = db.Customers
              .OrderByDescending(c => c.Value1)
              .Take(10);
(我真的鼓励您尝试使用比
Value1
更有意义的名称……)


编辑:即使在实体框架中,我通常在LINQ查询中使用
Take
——这是表示前N个结果的“LINQ方式”。如果你真的真的想使用 Tope,它提供了示例-但是你应该考虑为什么要使用<代码> Tope而不是<代码>使用。(您没有给我们提供任何上下文。)

我的错,我的意思是linq到实体。我知道这个语法。我特别询问了
top
语法。我找到了答案:
Top(1,新的ObjectParameter(“@CtidProdId”))。Select(item=>item.CtidProdId)。SingleOrDefault()
@EladBenda:Jon向你展示的是SQL的
Top
@EladBenda:。你还说你知道
FirstOrDefault
,这与知道
Take
不同。如果你要问错误的问题,你应该期望得到的答案不包括你想要的。老实说,即使在实体框架中,我也会使用
Take
,除非您确实需要使用
Top
。当你的问题含糊不清时,这真的没有帮助。
List<string> strs = new List<strs>() { "1", "2", "3", "4" };
var firstTwo = strs.Take(2);
var query = db.Customers
              .OrderByDescending(c => c.Value1)
              .Take(10);