java.sql.ResultSet向下兼容的接口,把它命名为Pageable,接口定义如下:
public interface Pageable extends java.sql.ResultSet{
/**返回总页数
*/
int getPageCount();
/**返回当前页的记录条数
*/
int getPageRowsCount();
/**返回分页大小
*/
int getPageSize();
/**转到指定页
*/
void gotoPage(int page) ;
/**设置分页大小
*/
void setPageSize(int pageSize);
/**返回总记录行数
*/
int getRowsCount();
/**
* 转到当前页的第一条记录
* @exception java.sql.SQLException 异常说明。
*/
void pageFirst() throws java.sql.SQLException;
/**
* 转到当前页的最后一条记录
* @exception java.sql.SQLException 异常说明。
*/
void pageLast() throws java.sql.SQLException;
/**返回当前页号
*/
int getCurPage();
}
这是一个对java.sql.ResultSet进行了扩展的接口,主要是增加了对分页的支持,如设置分页大小,跳转到某一页,返回总页数等等
我们需要实现这个接口,由于这个接口继承自ResultSet,并且它的大部分功能也都和ResultSet原有功能相同,所以这里使用了一个简单的Decorator模式
import java.sql.ResultSet;
//import java.util.*;public class Pagerow implements Pageable{

protected ResultSet rs=null;
protected int rowsCount;
protected int pageSize;
protected int curPage;/**
 *构造方法
 
public Pagerow(java.sql.ResultSet rs) throws java.sql.SQLException {
 
if(rs==null) throw new SQLException("given ResultSet is NULL");rs.last();
rowsCount=rs.getRow();
rs.beforeFirst();this.rs=rs;
}*/
  
/**返回当前页号
*/
public int getCurPage(){
return curPage;
}
/**返回总页数
*/
public int getPageCount() {
if(rowsCount==0) return 0;
if(pageSize==0) return 1;
//calculate PageCount
double tmpD=(double)rowsCount/pageSize;
int tmpI=(int)tmpD;
if(tmpD>tmpI) tmpI++;
return tmpI;
}
/**返回当前页的记录条数
*/
public int getPageRowsCount() {
if(pageSize==0) return rowsCount;
if(getRowsCount()==0) return 0;
if(curPage!=getPageCount()) return pageSize;
return rowsCount-(getPageCount()-1)*pageSize;
}
/**返回分页大小
*/
public int getPageSize() {
return pageSize;
}
/**返回总记录行数
*/
public int getRowsCount() {
return rowsCount;
}
/**转到指定页
*/
public void gotoPage(int page) {
if (rs == null)
return;
if (page < 1)
page = 1;
if (page > getPageCount())
page = getPageCount();
int row = (page - 1) * pageSize + 1;
try {
rs.absolute(row);
curPage = page;
}
catch (java.sql.SQLException e) {
}
}
/**
* 转到当前页的第一条记录
* @exception java.sql.SQLException 异常说明。
*/
public void pageFirst() throws java.sql.SQLException {
int row=(curPage-1)*pageSize+1;
rs.absolute(row);
}
/**
* 转到当前页的最后一条记录
* @exception java.sql.SQLException 异常说明。
*/
public void pageLast() throws java.sql.SQLException {
int row=(curPage-1)*pageSize+getPageRowsCount();
rs.absolute(row);
}
/**设置分页大小
*/
public void setPageSize(int pageSize) {
if(pageSize>=0){
this.pageSize=pageSize;
curPage=1;
}
}
}
但是在Pagerow编译过程中出现如下错误提示:"Pagerow.java不是抽象的,并且为覆盖java.sql.ResultSet中的抽象方法updateArray()"
不只是怎么回事?

解决方案 »

  1.   

    可能需要实现ResultSet构造函数中的某个功能
      

  2.   

    ResultSet 不是实际的类,好象是个接口哦~ 不能这样用的
      

  3.   

    ResultSet确是接口,Pageable编译运行都是正常的。问题出在Pagerow类的编译上,它对Pageable中新定义定义的方法都已实现,出错提示是指在ResultSet原有方法上的
      

  4.   

    Pageable编译运行都是正常的
    因为他也是接口啊,不需要实现方法的。Pagerow类不仅要实现Pageable的方法,也要实现在ResultSet里定义的方法的啊
      

  5.   

    是的 
    Pagerow里面定义的方法都是Pageable中声明的;至于ResultSet中定义的方法还需要逐一的在 
    它的扩展类中重新定义吗?
      

  6.   

    唉, 告诉你了,你还不信~ 、public class Pagerow extands RowSet implements Pageable这样也许就可以了
      

  7.   

    又多了一条错误 
    E:\JFiles\Pagerow.java:4: 找不到符号
    符号: 类 RowSet
    public class Pagerow extends RowSet implements Pageable{
                                 ^
    E:\JFiles\Pagerow.java:4: Pagerow 不是抽象的,并且未覆盖 java.sql.ResultSet 中的抽象方法 updateArray(java.lang.String,java.sql.Array)
    public class Pagerow extends RowSet implements Pageable{
           ^
    2 错误我import的是java.sql.*
      

  8.   

    RowSet同ResultSet一样是接口啊  刚才查到的
      

  9.   

    这么复杂的工作还是要用个IDE来做好一点。用写字板一个字累。主要是你要实现ResultSet的几十种方法啊。