为什么jdbc查询Oracle数据表只能查询到第一条数据

package 测试包;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Oracle存储过程 {

public static void main(String[] args) {
    Connection conn = null;
    Statement stmt = null;
    ResultSet res=null;
        try {
       Class.forName("oracle.jdbc.driver.OracleDriver");
        } catch (ClassNotFoundException e) {                      e.printStackTrace();
        }
        String url="jdbc:oracle:thin:@127.0.0.1:1521:Oraclename";
        String user="system";
        String password="GUO6";
        try {
   conn= DriverManager.getConnection(url,user,password);
    System.out.println("已经成功连接数据库!!!");
    stmt=conn.createStateme(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
         res=stmt.executeQuery("select * from newtable1");               while(res.next())
    {
     System.out.println(res.getString(1)+"   "+res.getString(2)+res.getString(3));
                }
    conn.close();//关闭连接数据库

    } catch (SQLException e) {
            // TODO Auto-generated catch block
        e.printStackTrace();
    }



}

}
以上的完整代码,结果只查出表的第一条记录,不过表是有10条记录的

我使用你的程序,在我本地运行,运行正常,程序没什么问题

直接用:conn.createStatement();不带参数

使用
String url="jdbc:oracle:thin:@127.0.0.1:1521:Oraclename";
String user="system";
String password="GUO6";

这个帐户直接登录可以看到9行记录吧?

[quote]结果集就只是查出了第一行的记录,剩下的9行没有查出来。什么原因真是的,我连数据库也不是一次两次了。。。。[/quote]

是不是你运行的太多,而又不释放,数据库那剩余的行锁了。重启数据库再试一试。

你上面用的ResultSet查询方式,在oracle中不能得到结果集,而是单条查询。
建议用存储过程查询oracle返回的结果集合。

去掉ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE 试一试