gpt4 book ai didi

java - 结果集不滚动

转载 作者:行者123 更新时间:2023-12-01 15:11:23 25 4
gpt4 key购买 nike

请看下面的代码

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();
}
}

此代码给出以下错误

java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]Invalid Descriptor Index
at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6956)
at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7113)
at sun.jdbc.odbc.JdbcOdbc.SQLGetDataInteger(JdbcOdbc.java:3810)
at sun.jdbc.odbc.JdbcOdbcResultSet.getDataInteger(JdbcOdbcResultSet.java:5637)
at sun.jdbc.odbc.JdbcOdbcResultSet.getInt(JdbcOdbcResultSet.java:582)
at normal.DatabaseHandler.searchData(DatabaseHandler.java:331)
at normal.SearchForm$ButtonAction.actionPerformed(SearchForm.java:470)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2341)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
at java.awt.Component.processMouseEvent(Component.java:6504)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6269)
at java.awt.Container.processEvent(Container.java:2229)
at java.awt.Component.dispatchEventImpl(Component.java:4860)
at java.awt.Container.dispatchEventImpl(Container.java:2287)
at java.awt.Component.dispatchEvent(Component.java:4686)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
at java.awt.Container.dispatchEventImpl(Container.java:2273)
at java.awt.Window.dispatchEventImpl(Window.java:2713)
at java.awt.Component.dispatchEvent(Component.java:4686)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:707)
at java.awt.EventQueue.access$000(EventQueue.java:101)
at java.awt.EventQueue$3.run(EventQueue.java:666)
at java.awt.EventQueue$3.run(EventQueue.java:664)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:680)
at java.awt.EventQueue$4.run(EventQueue.java:678)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:677)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:211)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:128)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:117)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:113)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:90)

这是为什么呢?如果我把

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

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

最佳答案

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

关于java - 结果集不滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12303010/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com