MySQL提高分页效率
下面就是大数据量时提高分页的效率的测试代码,分享给大家。
--提高分页效率:实现分页时只读取显示数据,需要先在数据库创建数据库“TestForPaging” useTestForPaging go --创建表SomeData createtableSomeData ( idintprimarykey, namevarchar(30)null, descriptiontext ) go --插入数据 insertintoSomeDatavalues(1,'num1','第1条') go insertintoSomeDatavalues(2,'num2','第2条') go insertintoSomeDatavalues(3,'num3','第3条') go insertintoSomeDatavalues(4,'num4','第4条') go insertintoSomeDatavalues(5,'num5','第5条') go --数据条目总数 selectcount(*)fromSomeData go --给每条记录添加一个数据级别 selectname,description,ROW_NUMBER()over(orderbyiddesc)asdataLevelfromSomeData go --查看指定的数据级别间的数据条目 selectdataLevel,name,descriptionfrom (selectname,description,row_number()over(orderbyiddesc)asdataLevelfromSomeData) asdatawithleverlwheredataLevelbetween2and4 go --实现查看指定的数据级别间的数据条目的存储过程 createprocedureGetDataPaged ( @startRowIndexint, @maximumRowsint, @sortvarchar ) AS --确保指定sort iflen(@sort)=0 set@sort='id' --带参数的查询 selectdataLevel,name,descriptionfrom (selectname,description,row_number()over(orderby@sortdesc)asdataLevelfromSomeData)ASdatawithleverl WHEREdataLevel>(@startRowIndex*10)ANDdataLevel<=(@startRowIndex*10+@maximumRows) go
以上就是本文的的全部内容,希望对大家的学习有所帮助。