oracle写分页的存储过程

本文介绍了一种使用PL/SQL过程实现的学生信息分页查询的方法。通过定义输入参数来指定查询列名、排序方式、当前页数及每页记录数,并返回游标以获取查询结果。该过程首先计算出每页显示数据的起始位置和结束位置,然后构造SQL语句进行分页查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  procedure Select_STU
  (
    p_lie in char,--要查询的列
    p_orderby in char,--按哪一列排序
    p_now in integer,--当前页
    p_size in integer,--每页有多少数据
    p_cur out cur--游标
  )
 as
   first  integer;--第一个数据
   later  integer;  --该页最后一个数据 
   sql_ char(200);
 begin
   first:=p_size*(p_now-1)+1;
   later:=p_size*p_now;
--'open p_cur for '
 sql_:=' select '||p_lie ||' from 
(select rownum as r,num,name from Student)t
where t.r between '||first|| ' and ' ||later|| 
' order by '|| p_orderby;
dbms_output.put_line(sql_);
open p_cur for sql_;
--execute immediate sql_;
end Select_STU;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值