jqgrid使用sql row_number进行分页

背景

系统中使用了jqgrid的展示,现在要处理10w+的数据量

现状

使用了全查询的,查询到了10w+的数据放到了datatable中,每次页面刷新需要9秒多,并且传递给另一个dll来处理一些事情。偶尔会出现StackOverFlow的异常问题,但是频率较大。

分析

现有的就有两个问题需要解决:

  1. 性能问题
  2. StackOverFlow的异常问题
起始

性能问题经过调查,sql语句查询完成之后至少4秒钟左右,因为是全查询,所以把尽力的条件都做了,效果不明显。

然后考虑用sql server的row_number函数进行直接分页,不依赖jqgrid本身的分页机制,由于每次分页只有几十条,所以速度非常的快,基本上就是秒查,==> 为什么差距这么大?这块我认为是查询的时候非常的快,sql 返回数据展示部分就会非常的大,毕竟使用row_number函数是需要给每一条数据进行标号码的,之后为了验证自己的猜想,未使用分页使用了top 20的条件查询,速度也是秒查,所以至少一半认为是大数据量返回时会耗时(这个不能解释为什么sql语句复杂查询的时候,返回结果只有非常少的数据量时,耗费时间也非常的严重)

在使用了几十条的返回结果时,StackOverFlow的问题也会得到解决。

歧途

之后在使用jqgrid的时候,之前jqgrid本身根据数据量的多少进行分页等一系列自动操作,现在直接绑定的数据源就是分好页的,自己尝试自己付页码和总条数没有找到属性等。

之后查询jqgrid的文档,发现js办的jqgrid是有这种功能的,数据源自己分页,然后返回总条数等就可以了。

自己怨念很深,查询trirand的asp.net使用jqgrid的时候,没有仔细看文档,虽然发现了示例,但是没有看c#的代码,一直以为是数据源的sql语句jqgrid会自动分页,所以速度很快。

心塞

之后自己写了分页的代码,然后插入了10w+的空白然后进行jqgrid绑定,然后遇到的排序的问题,自己又写了大段的代码进行jqgrid的原理适配,最终还是还有非常大的问题,遂决定放弃代码优化。

解决

之后还是看着trirand的示例网页,把所有的内容都读了一遍,发现了自定义的分页方法DataRequesting,然后就一点点代码搞定!

总结

如果是第三方控件之类的,一定要仔细读帮助手册。

时间: 2024-10-12 17:23:37

jqgrid使用sql row_number进行分页的相关文章

SQL Server的分页优化及Row_Number()分页存在的问题

[导读] 最近有项目反应,在服务器CPU使用较高的时候,我们的事件查询页面非常的慢,查询几条记录竟然要4分钟甚至更长,而且在翻第二页的时候也是要这么多的时间,这肯定是不能接受的,也是让现场用SQLServerProfiler把语 最近有项目反应,在服务器CPU使用较高的时候,我们的事件查询页面非常的慢,查询几条记录竟然要4分钟甚至更长,而且在翻第二页的时候也是要这么多的时间,这肯定是不能接受的,也是让现场用SQLServerProfiler把语句抓取了上来. 用ROW_NUMBER()进行分页

使用SQL Server 2005 新的语法ROW_NUMBER()进行分页的两种不同方式的性能比较

相比在SQL Server 2000 中使用的分页方式,在SQL Server 2005中使用新的语法ROW_NUMBER()来分页效率要高出很多,但是很多人在使用ROW_NUMBER()这种分页方式时,使用的方法并不正确,以下列出不正确的和正确的做法并做简单分析: 首先假设我们已经创建了如下的表和索引并初始化了100万条数据: CREATE TABLE [dbo].[Users] ( [ID] [int] IDENTITY(1,1) NOT NULL, [Name] [varchar](50)

用oracle中的Row_Number实现分页

Row_Number实现分页 1:首先是 select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1 生成带序号的集合 2:再查询该集合的 第 1  到第 5条数据 select * from     (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp    where rowNumber betwee

sqlserver2005使用row_number() over分页的实现方法

sqlserver2005使用row_number() over分页的实现方法 sqlserver2005使用row_number() over分页的实现方法,需要的朋友可以参考下. 语法:ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN) <BR> 例子: select * from (  select *, ROW_NUMBER() OVER(Order by a.CreateTime DESC ) AS RowNumber fro

Sql Server 数据分页

1.引言 在列表查询时由于数据量非常多,一次性查出来会非常慢,就算一次查出来了,也不能一次性显示给客户端,所以要把数据进行分批查询出来,每页显示一定量的数据,这就是数据要分页. 2.常用的数据分页方法 我们经常会碰到要取n到m条记录,就是有分页思想,下面罗列一下一般的方法. 我本地的一张表 tbl_FlightsDetail,有300多W记录,主键 FlightsDetailID(Guid),要求按照FlightsDetailID排序 取 3000001 到3000010 之间的10条记录,也是

SQL SERVER 通用分页存储过程

SQL SERVER 通用分页存储过程 从SQLSERVER 2005开始,提供了Row_Number()函数,利用函数生成的Index来处理分页,按照正常的逻辑思维都是传pageIndex和pageSize来完成分页,昨天前端和我沟通,他们使用jQuery.DataTable.js插件,而且经过了公司底层的封装,pageIndex需要变动一下,变成pageIndex*pageSize来传. 也就是说按每页显示30条算,第一次传0,第二次传30这样来计算,我也是醉了. 1.传pageIndex和

sql server存储过程分页,行变列

CREATE PROCEDURE [dbo].[PROC_GetPriviousAndNextDetailContent]@Index varchar(20),--表主键@Table varchar(100),--从哪个表获取数据@Columns varchar(100),--需要获取哪些字段@OrderStr varchar(100),--排序字段及方式@Where1    varchar(100),--row_number中的初步过滤条件@Where2 varchar(100)--当前要查询

Sql Server通用分页存储过程

Sql Server2005通用分页存储过程 CREATE PROCEDURE [dbo].[Common_GetPagedList] ( @TableName nvarchar(100), --表名 @ColumnNames nvarchar(1000) = '*', --字段名集合(全部字段为*,其它逗号分隔) @OrderClause nvarchar(1000), --排序从句(不包含order by) @WhereClause nvarchar(1000) =N' 1=1 ',   

浅谈SQL Server数据库分页

数据库分页是老生常谈的问题了.如果使用ORM框架,再使用LINQ的话,一个Skip和Take就可以搞定.但是有时由于限制,需要使用存储过程来实现.在SQLServer中使用存储过程实现分页的已经有很多方法了.之前在面试中遇到过这一问题,问如何高效实现数据库分页.刚好上周在业务中也遇到了这个需求,所以在这里简单记录和分享一下. 一 需求 这里以SQLServer的示例数据库NorthWind为例,里面有一张Product表,现在假设我们的需求是要以UnitPrice降序排列,并且分页,每一页10条