我创建了一个将数据插入MSAccess数据库的程序。当我执行语句时,我得到一个java.sql.SQLException:[Microsoft][ODBC驱动程序管理器]无效的游标状态。数据库为空。我试图通过执行 resultSet.next() 将光标移动到第一行;但它不起作用。谁能告诉我问题是什么?这是我到目前为止的代码:
用于创建连接的代码:
public LogInInterface() {
initComponents();
//Database Connection Setup.
try{
String Driver = "sun.jdbc.odbc.JdbcOdbcDriver";
Class.forName(Driver);
//ErrorLabel.setText("DRIVER LOADED");
//ErrorLabel.setForeground(new Color(0, 204, 0));
String Login = "jdbc:odbc:JavaDB";
connection = DriverManager.getConnection(Login);
statement = connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
resultSet = statement.executeQuery(SQL);
//ErrorLabel.setText("DATABASE CONNECTION IS READY");
//ErrorLabel.setForeground(new Color(0, 204, 0));
//ErrorLabel.setText(null);
}catch(Exception e){
ErrorLabel.setText("DATABASE CONNECTION ERROR (Code 1)");
e.printStackTrace();
}
}
插入数据库的代码:
private void RegisterButtonActionPerformed(ActionEvent e) {
// TODO add your code here
try{
String FName = FirstNameTextField.getText();
String LName = LastNameTextField.getText();
resultSet.moveToInsertRow();
resultSet.updateString(2,FName );
resultSet.updateString(3,LName);
resultSet.updateRow();
statement.close();
resultSet.close();
statement = connection.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
resultSet = statement.executeQuery(SQL);
}catch(Exception e1){
ErrorLabel.setText("ACCOUNT COULD NOT BE CREATED AT THIS TIME (Code 2)");
e1.printStackTrace();
}
}
完整的堆栈跟踪:
java.sql.SQLException: [Microsoft][ODBC Driver Manager] Invalid cursor state
at sun.jdbc.odbc.JdbcOdbcResultSet.setPos(JdbcOdbcResultSet.java:5271)
at sun.jdbc.odbc.JdbcOdbcResultSet.updateRow(JdbcOdbcResultSet.java:4171)
at com.company.LogInInterface.RegisterButtonActionPerformed(LogInInterface.java:251)
at com.company.LogInInterface.access$1400(LogInInterface.java:12)
at com.company.LogInInterface$9.actionPerformed(LogInInterface.java:545)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
at java.awt.Component.processMouseEvent(Component.java:6297)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3275)
at java.awt.Component.processEvent(Component.java:6062)
at java.awt.Container.processEvent(Container.java:2039)
at java.awt.Component.dispatchEventImpl(Component.java:4660)
at java.awt.Container.dispatchEventImpl(Container.java:2097)
at java.awt.Component.dispatchEvent(Component.java:4488)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4575)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4236)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4166)
at java.awt.Container.dispatchEventImpl(Container.java:2083)
at java.awt.Window.dispatchEventImpl(Window.java:2489)
at java.awt.Component.dispatchEvent(Component.java:4488)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:674)
at java.awt.EventQueue.access$400(EventQueue.java:81)
at java.awt.EventQueue$2.run(EventQueue.java:633)
at java.awt.EventQueue$2.run(EventQueue.java:631)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:98)
at java.awt.EventQueue$3.run(EventQueue.java:647)
at java.awt.EventQueue$3.run(EventQueue.java:645)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:644)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:269)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:184)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:174)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:169)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
将ResultSet.updateRow
替换为ResultSet.insertRow
。来自ResultSet.updateRow
的Javadoc
使用此结果集对象的当前行的新内容更新基础数据库。当光标位于插入行上时,不能调用此方法。
另请查看您在方法中调用的 Javadoc of ResultSet.moveToInsertRow
:
将光标移动到插入行。当光标位于插入行上时,将记住当前光标位置。插入行是与可更新结果集关联的特殊行。它本质上是一个缓冲区,可以在将行插入结果集之前通过调用更新程序方法来构造新行。当光标位于插入行上时,只能调用更新程序、getter 和 insertRow 方法。每次调用此方法时,在调用 insertRow 之前,都必须为结果集中的所有列指定一个值。必须先调用更新程序方法,然后才能对列值调用 getter 方法。