Java 结果集没有滚动

Java 结果集没有滚动,java,jdbc,Java,Jdbc,请看一下下面的代码 public List searchData(String query) { List data = new ArrayList(); try { createConnection(); Statement st = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDAT

请看一下下面的代码

public List searchData(String query)
    {
        List data = new ArrayList();

        try
        {
             createConnection();

             Statement st = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
             ResultSet rs = st.executeQuery(query);


                while(rs.next())
                {

                 data.add(rs.getString(2));
                 data.add(rs.getString(11));
                 data.add(rs.getString(12));
                 data.add(rs.getInt(3));
                 data.add(rs.getInt(4));
                 data.add(rs.getInt(5));
                 data.add(rs.getInt(6));
                 data.add(rs.getString(7));
                 data.add(rs.getString(8));
                 data.add(rs.getString(9));
                 data.add(rs.getString(10));

                }


                for(int i=0;i<data.size();i++)
                {
                    System.out.println(data.get(i));
                }

                System.out.println("Size of the array: "+data.size());



        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
        finally
        {
            closeConnection();
        }
}
为什么会这样?如果我把

data.add(rs.getString(11));
data.add(rs.getString(12));

最后,这个错误没有发生。我甚至将结果集设置为可滚动!为什么会这样?请帮忙

“滚动”结果集与在不同行之间来回移动有关。您在获取给定行的列值时遇到问题。一些jdbc驱动程序对列顺序很敏感,我认为这不是设置问题。我想说的是,您要么需要按顺序阅读这些列,要么可能需要寻找不同的jdbc驱动程序。

不要使用数字作为索引。从resultset检索数据时始终使用列名。这将使在不影响现有代码的情况下更容易对表进行修改。这不是问题所在。我现在做了。不,太棒了。是的,我在“while(rs.next())”中做了所有这些,它检查相同的原始数据,并继续前进。我决定把所有这些数据分成不同的变量,然后做我需要的任何事情。非常感谢您的回复:)
data.add(rs.getString(11));
data.add(rs.getString(12));