我正在尝试使用网格分页。以下方法将表中的所有内容都提供给网格。我如何考虑开始和限制开始是页码的位置,限制是每页的记录。基本上extjs工具栏查找我的方法返回开始和按需限制。我尝试了很多解决方案,但似乎无法工作。这就是我以简单的方式把它放在这里的原因。
这是我的c#end
public string myRecord(int start, int limit)
{
List<gridPaging> result = new List<gridPaging>();
using (SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["ApplicationServices2"].ConnectionString))
{
SqlCommand cmd = con.CreateCommand();
cmd.CommandText = "SELECT * FROM myTable ORDER BY Q1";
con.Open();
SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
gridPaging gp = new gridPaging();
gp.Column1 = reader["Column1"].ToString().Trim();
gp.Column2 = reader["Column2"].ToString().Trim();
gp.Column3 = reader["Column3"].ToString().Trim();
gp.Column4 = reader["Column4"].ToString().Trim();
result.Add(gp);
}
return JsonConvert.SerializeObject(result);
}
}
答案 0 :(得分:3)
如果这与您当前的实现类似,您可以修改SQL以利用ROW_NUMBER
:T-SQL:Paging with ROW_NUMBER()
或者,如果您有某种LINQ实现,则可以使用.Skip()
和.Take()
方法进行分页。
答案 1 :(得分:2)
在T-SQL中,您有两个内置插件可以帮助您;第一个是Row_Number
函数,它按照特殊的ORDER BY子句的顺序为结果集的每一行分配一个唯一的,增加的序数,第二个是TOP
关键字,它限制了最大值要返回的行数。
基本上,您的查询应如下所示:
SELECT TOP @limit * FROM myTable WHERE (ROW_NUMBER() OVER (ORDER BY Q1)) > @limit * @start ORDER BY Q1
然后使用Command.CreateParameter从C#代码中插入参数@start和@limit的值。例如,对于结果的第三页(使用零索引start
值为2),每页有15个结果,这将评估为语句
SELECT TOP 15 * FROM myTable WHERE (ROW_NUMBER() OVER (ORDER BY Q1)) > 30 ORDER BY Q1
...它提供从31到45的整个查询中的行,前两页的查询分别产生了1-15和16-30行。