SQLServer数据库存储过程分页是怎样的?
存储过程:create Procedure pname
( @pageIndex int,@pageSize)
as
select * from tableName order by id
offset @pageIndex * pageSize fetch next pageSize rows only
分页:
sqlserver 在2008之前 使用 top 和 not int top 的方式来做分页
2008以后使用 row_number() 函数作为分页关键函数
2012使用 offset 1 fetch next 10 rows only
你问了2个问题,你可以优先把视图,存储过程,触发器等弄明白,分页是查询,在存储过程里可以写复杂的sql文,只是在运行时是预编译和参数化查询防止sql注入
延伸阅读
高效的mysql分页方法及原理?
一,最常见MYSQL最基本的分页方式:
select * from content order by id desc limit 0, 10
在中小数据量的情况下,这样的SQL足够用了,唯一需要注意的问题就是确保使用了索引。随着数据量的增加,页数会越来越多,查看后几页的SQL就可能类似:
select * from content order by id desc limit 10000, 10
就是越往后分页,LIMIT语句的偏移量就会越大,速度也会明显变慢。
此时,可以通过2种方式:
一,子查询的分页方式来提高分页效率,飘易用的SQL语句如下:
SELECT * FROM content WHERE id> (SELECT id FROM content ORDER BY id desc LIMIT “.($page-1)*$pagesize.”, 1) ORDER BY id desc LIMIT $pagesize
为什么会这样呢?因为子查询是在索引上完成的,而普通的查询时在数据文件上完成的,通常来说,索引文件要比数据文件小得多,所以操作起来也会更有效率。(via)通过explain SQL语句发现:子查询使用了索引!
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY content range PRIMARY PRIMARY 4 NULL 6264 Using where
2 SUBQUERY content index NULL PRIMARY 4 NULL 27085 Using
什么是sql分段查询?
分段查询也可以叫分页查询,即根据数据库表中的某个字段按一定数值分段查出来,这样就是分段查询
SQLServer数据库存储过程分页是怎样的?
sqlserver从表中读取数据,跳过了查询返回的前10行,然后只返回接下来的5行数据,这个是sqlserver2012,t-sql的新功能,offset/fetch即席查询分页功能
SQLServer两种分页的存储过程使用介绍?
存储过程:createProcedurepname(@pageIndexint,@pageSize)asselect*fromtableNameorderbyidoffset@pageIndex*pageSizefetchnextpageSizerowsonly分页:sqlserver在2008之前使用top和notinttop的方式来做分页2008以后使用row_number()函数作为分页关键函数2012使用offset1fetchnext10rowsonly你问了2个问题,你可以优先把视图,存储过程,触发器等弄明白,分页是查询,在存储过程里可以写复杂的sql文,只是在运行时是预编译和参数化查询防止sql注入