分页存储过程 方一

分页存储过程的使用

一、存储过程

  存储过程就像数据库中运行的方法(函数)

  优点:速度快,在数据库中保存的存储过程语句都是编译过的

          允许模块化程序设计

          提高系统的安全性,防止SQL注入

          减少网络流量,只传输存储过程的名称

二、存储过程分类

 1、系统存储过程

     由系统定义,存放在master数据库中

     名称以"sp_"开头或"xp_"开头

 2、自定义存储过程

     由用户在自己的数据库中创建的存储过程usp

三、创建存储过程

   Create proc[edure]  存储过程名

   @参数1 数据类型=默认值 output,

   @参数n 数据类型=默认值 output

   as 

    SQL语句

四、存储过程的使用

复制代码
 1 create procedure usp_FenYe
 2 @pageIndex int,
 3 @pageCount int=10,
 4 @pageTotalCount int output
 5 as
 6 begin
 7   --计算出总页数
 8   declare @totalData int;
 9   set @totalData=(select count(*) from T)
10   set @pageTotalCount=Ceiling(@totalData*1.0/@pageCount);
11   --得到数据
12   select * from
13   (select *,num=row_number() over(order by id) from T) as t
14    where t.num between 
15     @pageCount * (@pageInde-1)+ and@pageCount* @pageIndex;
16 end
17 go
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值