java mysql 分页_java web 开发 分页功能 mysql数据库 | 学步园

84ab98ec24af2fb7cc062ad010be12f3.png

list.jsp:

系统公告

Previous

${i} ${i} Next

list.java:

public ArrayList getNotices(int offset,int recordsPerPage){

ResultSet rs=null;

PreparedStatement ps =null;

ArrayList notices = new ArrayList();

Connection conn = JdbcUtils.getConnection();

String sql = "select SQL_CALC_FOUND_ROWS id,title,content,person,filepath,pubtime from notice order by id desc limit ?,? ";

try {

ps = conn.prepareStatement(sql);

ps.setInt(1, offset);

ps.setInt(2, recordsPerPage);

rs = ps.executeQuery();

while(rs.next()){

Notice notice = new Notice();

notice.setId(rs.getInt("id"));

notice.setTitle(rs.getString("title"));

notice.setContent(rs.getString("content"));

notice.setPerson(rs.getString("person"));

notice.setFilepath(rs.getString("filepath"));

notice.setPubtime(rs.getString("pubtime"));

notices.add(notice);

}

rs.close();

rs = ps.executeQuery("SELECT FOUND_ROWS()");

if(rs.next())

this.noOfRecords = rs.getInt(1);

} catch (Exception e) {

e.printStackTrace();

}

return notices;

}

servlet:

//处理乱码

request.setCharacterEncoding("UTF-8");

response.setContentType("text/html; charset=gbk");

int page = 1;

int recordsPerPage = 10;

if(request.getParameter("page") != null)

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

NoticeDAO nd = new NoticeDAOImpl();

ArrayList notices = nd.getNotices((page-1)*recordsPerPage,recordsPerPage);

int noOfRecords = nd.getNoOfRecords();

int noOfPages = (int) Math.ceil(noOfRecords * 1.0 / recordsPerPage);

request.setAttribute("notices", notices);

request.setAttribute("noOfPages", noOfPages);

request.setAttribute("currentPage", page);

request.getRequestDispatcher("noticelist.jsp").forward(request, response);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值