java web jdbc oracle 分页,jdbc连接oracle及简单分页

该博客展示了如何使用 Java 实现 Oracle 数据库的分页查询。通过 `Class.forName()` 加载 JDBC 驱动,建立数据库连接,并利用 `Statement` 对象执行 SQL 查询语句,获取指定页码的数据。同时,计算总页数,将数据和页码列表存入请求属性中,供前端展示。整个过程涉及 JDBC 连接、参数解析、数据转换等步骤。
摘要由CSDN通过智能技术生成

public class OracleFenye extends Action {

private int pageNow = 1;

private int totalPage = 0;

private int pageSize = 3;

@SuppressWarnings("unchecked")

@Override

public ActionForward execute(ActionMapping mapping, ActionForm form,

HttpServletRequest request, HttpServletResponse response) throws Exception {

try {

Class.forName("oracle.jdbc.driver.OracleDriver");

Connection conn = DriverManager.getConnection(

"jdbc:oracle:thin:@localhost:1521:orcldb", "scott", "tiger");

Statement st = conn.createStatement();

// 分页

String pageNo = request.getParameter("pageNow");

if (pageNo != null) {

pageNow = Integer.parseInt(request.getParameter("pageNow"));

}

ResultSet rs = st

.executeQuery("select * from (select a1.*,rownum rn from (select * from emp) a1 where rownum <="

+ pageSize

* pageNow

+ ") where rn >="

+ ((pageNow - 1) * pageSize + 1)

+ " ");

List list = new ArrayList();

while (rs.next()) {

list.add(rs.getString(2));

}

// 计算

totalPage rs = st.executeQuery("select count(*) from emp");

List pageList = new ArrayList();

while (rs.next()) {

int rsno = rs.getInt(1);

if (rsno % 2 == 0) {

totalPage = rsno / pageSize + 1;

} else {

totalPage = rsno / pageSize;

}

}

for (int i = 1; i <= totalPage; i++) {

pageList.add(i);

}

request.setAttribute("rsList", list);

request.setAttribute("pageList", pageList);

rs.close();

st.close();

conn.close();

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

}

return mapping.findForward("fenye");

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值