LINQ to SQL 从表中每第 N 行
有人知道如何编写 LINQ to SQL 语句来返回表中的每第 n 行吗?我需要获取分页数据网格中每个页面顶部的项目标题,以便快速用户扫描.因此,如果我想要第一条记录,那么之后的每第三条记录,来自以下名称:
Anybody know how to write a LINQ to SQL statement to return every nth row from a table? I'm needing to get the title of the item at the top of each page in a paged data grid back for fast user scanning. So if i wanted the first record, then every 3rd one after that, from the following names:
艾米、埃里克、杰森、乔、约翰、乔希、玛丽贝尔、保罗、史蒂夫、汤姆
Amy, Eric, Jason, Joe, John, Josh, Maribel, Paul, Steve, Tom
我会得到艾米、乔、玛丽贝尔和汤姆.
I'd get Amy, Joe, Maribel, and Tom.
我怀疑这可以做到... LINQ to SQL 语句已经结合排序和分页调用了 ROW_NUMBER() SQL 函数.我只是不知道如何取回每 n 个项目.SQL 语句类似于 WHERE ROW_NUMBER MOD 3 = 0
,但我不知道用于获取正确 SQL 的 LINQ 语句.
I suspect this can be done... LINQ to SQL statements already invoke the ROW_NUMBER() SQL function in conjunction with sorting and paging. I just don't know how to get back every nth item. The SQL Statement would be something like WHERE ROW_NUMBER MOD 3 = 0
, but I don't know the LINQ statement to use to get the right SQL.
推荐答案
有时,TSQL 是要走的路.我会在这里使用 ExecuteQuery
:
Sometimes, TSQL is the way to go. I would use ExecuteQuery<T>
here:
var data = db.ExecuteQuery<SomeObjectType>(@"
SELECT * FROM
(SELECT *, ROW_NUMBER() OVER (ORDER BY id) AS [__row]
FROM [YourTable]) x WHERE (x.__row % 25) = 1");
你也可以换掉n
:
var data = db.ExecuteQuery<SomeObjectType>(@"
DECLARE @n int = 2
SELECT * FROM
(SELECT *, ROW_NUMBER() OVER (ORDER BY id) AS [__row]
FROM [YourTable]) x WHERE (x.__row % @n) = 1", n);
相关文章