----oracle 代码
----说明部分
CREATE OR REPLACE PACKAGE CURSPKG AS
TYPE refCursorType IS REF CURSOR;
procedure sp_Page(p_PageSize int, --每页记录数
p_PageNo int, --当前页码,从 1 开始
p_SqlSelect varchar2, --查询语句,含排序部分
p_SqlCount varchar2, --获取记录总数的查询语句
p_OutRecordCount out int, --返回总记录数
p_OutCursor out refCursorType);
END;
---包体
create or replace package body CURSPKG is
procedure sp_Page(p_PageSize int, --每页记录数
p_PageNo int, --当前页码,从 1 开始
p_SqlSelect varchar2, --查询语句,含排序部分
p_SqlCount varchar2, --获取记录总数的查询语句
p_OutRecordCount out int, --返回总记录数
p_OutCursor out refCursorType) is
v_sql varchar2(3000);
v_count int;
v_heiRownum int;
v_lowRownum int;
begin
----取记录总数
execute immediate p_SqlCount
into v_count;
p_OutRecordCount := v_count;
----执行分页查询
v_heiRownum := p_PageNo * p_PageSize;
v_lowRownum := v_heiRownum - p_PageSize + 1;
v_sql := 'SELECT * FROM (SELECT A.*, rownum rn
FROM (' || p_SqlSelect || ') A
WHERE rownum <= ' || to_char(v_heiRownum) || ') B
WHERE rn >= ' || to_char(v_lowRownum);
--注意对rownum别名的使用,第一次直接用rownum,第二次一定要用别名rn
OPEN p_OutCursor FOR v_sql;
end sp_Page;
end;
/*/////java代码 */
public Object[] findStuffByQuary(String name,String qualitiy,String type,String level, int Npage, int PageSize) {
String sql_data = "";
String sql_count = "";
String call = "{call CURSPKG.SP_PAGE(?,?,?,?,?,?)}";
Connection conn = connectionMgr.getCon();
CallableStatement ps;
Object[] obj = new Object[2];
List<VTmarketTgoods> list = new ArrayList<VTmarketTgoods>();
int countsize = 0;
try {
ps = conn.prepareCall(call);
ps.setInt(1, PageSize); // 每页数量
ps.setInt(2, Npage); // 页码
// 查询商店能购买的物品
// 取数据的sql
ps.setString(3, sql_data);
// 取数据个数的sql
ps.setString(4, sql_count);
// 输出数据行数
ps.registerOutParameter(5,OracleTypes.INTEGER);
// 输出游标记录集
ps.registerOutParameter(6, OracleTypes.CURSOR);
ps.execute();
countsize = ((OracleCallableStatement) ps).getInt(5);
ResultSet rs = ((OracleCallableStatement) ps).getCursor(6);
while (rs.next()) {
VTmarketTgoods tsg = new VTmarketTgoods();
filldata(tsg, rs);
list.add(tsg);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
obj[0] = list; obj[1] = countsize;
return obj;
}
分享到:
相关推荐
java实现oracle分页策略完整版,可当做参考类使用,有详细注释,适合初学者。
NULL 博文链接:https://abstractforever.iteye.com/blog/606827
mysql、sqlserver、oracle分页,java分页统一接口实现
java+Oracle分页,java操作oracle视图,存储过程。
完整的java+oracle 分页代码,供初学者使用
源代码实现的实在Java web与Oracle数据开发过程中的分页功能,代码不难,看看就能看懂,使用其中的核心代码能够轻易实现分页功能。希望对初学者有一定的帮助。
Oracle的SQL分页实践
java代码与oracle 函数包实现 jsp分页
java 调用Oracle存储过程进行分页详解
关于oracle 的分页、翻页的java源代码,结合JDBC连接数据库实现,比较基础的JDBC结合swing图形框架实现,适合Java初学者使用
这是我自己改的分页代码 呵呵 写了将近一个星期 只有一个控制类和一个jsp页 方便阅读和修改 只要修改test.java里面的数据库连接和表名就可以用了 希望大家工作和学习顺利 里面的class12.jar这个包是因为我的数据库...
oracle数据库级分页 老师写的自己项目中都用这个
//构造函数实例化接收一个pagetype和PaginationBean对象 public Page(String pagetype, PaginationBean pagination) { this.pagetype = pagetype; this.pagination = pagination; } /** * * */ ...
Java Oracle实现分页功能.pdf
java调用Oracle的分页存储过程,只要简单的处理就能实现常用的功能,固定的过程实现对不同表数据的分页,是一段好用的代码
完美整合(通用分页)SSH+Oracle (需要自己加入jar包,只是源码)
mybatis 分页 mybatis-generate Oracle数据库 大家知道mybatis自动生成代码是没有分页功能的 我在网上找了很久 有很多内容 但正真可以使用的少之又少 本人整合了网上的资源 整理了基于Oracle数据库的mybatis插件 ...
ibatis调用oracle存储过程分页
3种java分页源程序 数据库用oracle
java调用oracle分页存储过程,存储过程保存在sql文件夹下,可以直接运行。 实现了输入表名、每页显示记录数、当前页、排序字段,返回总记录数,总页数,和结果集。