又到了毕设的季节,有位同学问我真分页的问题,就写个例子参考参考吧

oracle语句使用ROWNUM真分页

sql = "select * from ( select pid,name,price,amount,ROWNUM rn from product where ( name LIKE ? or price LIKE ? or amount LIKE ? ) AND ROWNUM < = ? order by pid ) temp where temp.rn > ?

pstmt = conn.prepareStatement(sql);

pstmt.setString(1,"%"+keyword+"%");

pstmt.setString(2,"%"+keyword+"%");

pstmt.setString(3,"%"+keyword+"%");

pstmt.setString(4,"%"+keyword+"%");

pstmt.setInt(5,"%"+keyword+"%");

pstmt.setInt(6,"%"+keyword+"%");

rs = pstmt.executeQuery();

相应的mysql真分页写法(用limit)

String sql = "select * from product where name like ? or note like ? or price like ? or amount like ? order by pid LIMIT ?,?"

this.pstmt = conn.prepareStatement(sql);

this.pstmt.setString(1,"%"+keyword+"%");

this.pstmt.setString(2,"%"+keyword+"%");

this.pstmt.setString(3,"%"+keyword+"%");

this.pstmt.setString(4,"%"+keyword+"%");

this.pstmt.setInt(5,(currentPage-1)*linesize);

this.pstmt.setInt(6,linesize);

ResultSet rs = pstmt.executeQuery();