现在的位置: 首页 > 综合 > 正文

Java中取数据库用的ResultSet问题

2013年04月02日 ⁄ 综合 ⁄ 共 897字 ⁄ 字号 评论关闭
这段时间做java项目,在操作数据库的时候,犯了一个错误,请看下面的程序

.......                        //前面连接数据库方面的省略
ResultSet  result = statement.executeQuery(strSQL);

//开始读取数据并写到List中
if (result.next()) {
//有数据
  result.first(); 

  while (result.next()) {
        lstData.add(result.getString("columname"));
  }
}

结果一看数据库,少了一条数据,问题出在哪里呢?

一看帮助,原来是next的问题,在第一次执行result.next()之前,result并不指向第一行数据,执行以后才指向第一条数据,如果第一条数据我们说他的索引是0的话,那么第一次执行result.next()之前,可以理解成result指向的索引为-1(个人意见),而first()方法同样也是将result指向第一行数据,所以在后面执行while循环的时候,数据就从第二行开始取了。于是上面的程序可改成

if (result.next()) {
//有数据
  result.first(); 
  lstData.add(result.getString("columname"));

  while (result.next()) {
        lstData.add(result.getString("columname"));
  }
}

这样就没有错误了,但是这样写总感觉有点累赘,于是再改成下面的情况

  while (result.next()) {
        lstData.add(result.getString("columname"));
  }
//到这里再判断数据有没有
if (lstData.size() > 0) {
  //有数据
} else {
  //没有数据
}

结合上面两个方法,其实各有适合的场合,如果只是判断数据有没有 直接用
if (result.next()) {
//有数据
}
就可以了,如果程序里面要取出数据并处理 那么最后一种方法应该更好一些吧。

抱歉!评论已关闭.