2013-08-07 184 views
0

我想將數據集添加到我的MS Access數據庫中。但是我總是在SQL語句中的executeUpdate語句中出現語法錯誤。如果有人能幫助我,那會很棒。語法錯誤插入語句java

在這裏,您可以看到錯誤:

java.sql.SQLException: [Microsoft][ODBC-Treiber für Microsoft Access] Syntaxfehler in der INSERT INTO-Anweisung. 
at sun.jdbc.odbc.JdbcOdbc.createSQLException(Unknown Source) 
at sun.jdbc.odbc.JdbcOdbc.standardError(Unknown Source) 
at sun.jdbc.odbc.JdbcOdbc.SQLExecute(Unknown Source) 
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.execute(Unknown Source) 
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.executeUpdate(Unknown Source) 
at verwaltung.ListenerRegistrieren.addBenutzer(ListenerRegistrieren.java:47) 
at verwaltung.ListenerRegistrieren.actionPerformed(ListenerRegistrieren.java:28) 
at javax.swing.AbstractButton.fireActionPerformed(Unknown Source) 
at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source) 
at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source) 
at javax.swing.DefaultButtonModel.setPressed(Unknown Source) 
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source) 
at java.awt.Component.processMouseEvent(Unknown Source) 
at javax.swing.JComponent.processMouseEvent(Unknown Source) 
at java.awt.Component.processEvent(Unknown Source) 
at java.awt.Container.processEvent(Unknown Source) 
at java.awt.Component.dispatchEventImpl(Unknown Source) 
at java.awt.Container.dispatchEventImpl(Unknown Source) 
at java.awt.Component.dispatchEvent(Unknown Source) 
at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source) 
at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source) 
at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source) 
at java.awt.Container.dispatchEventImpl(Unknown Source) 
at java.awt.Window.dispatchEventImpl(Unknown Source) 
at java.awt.Component.dispatchEvent(Unknown Source) 
at java.awt.EventQueue.dispatchEventImpl(Unknown Source) 
at java.awt.EventQueue.access$200(Unknown Source) 
at java.awt.EventQueue$3.run(Unknown Source) 
at java.awt.EventQueue$3.run(Unknown Source) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) 
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) 
at java.awt.EventQueue$4.run(Unknown Source) 
at java.awt.EventQueue$4.run(Unknown Source) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) 
at java.awt.EventQueue.dispatchEvent(Unknown Source) 
at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source) 
at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source) 
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source) 
at java.awt.EventDispatchThread.pumpEvents(Unknown Source) 
at java.awt.EventDispatchThread.pumpEvents(Unknown Source) 
at java.awt.EventDispatchThread.run(Unknown Source) 

這是一個錯誤的基礎上的代碼。它是在的executeUpdate() - 聲明:

try { 

    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); 
    Connection conn = DriverManager.getConnection("jdbc:odbc:MSAccess"); 
    PreparedStatement pstm; 
    pstm = conn.prepareStatement("Insert Into Benutzer (Benutzername, Vorname, Nachname, E-Mail) values (?,?,?,?)"); 

    // SQL Statements 
    pstm.setString(1, gui.benutzername.getText()); 
    pstm.setString(2, gui.vorname.getText()); 
    pstm.setString(3, gui.nachname.getText()); 
    pstm.setString(4, gui.email.getText()); 
    pstm.executeUpdate(); 

    } catch (Exception e) { 
     e.printStackTrace(); 
    } 

我找不到語法錯誤!有人能幫我嗎?

謝謝

+0

您的表格是否包含4列? –

+2

我懷疑電子郵件中的連字符造成麻煩 – bowmore

+0

@ihsankocak否它包含更多,但我只想在此插入語句中填寫4。 – JUNGE

回答

0

您需要添加您的表中的所有列的值,否則Java JDBC將拋出和錯誤。

如果你有一個用戶名和密碼爲2列的用戶,你的代碼將看起來像你的prepareStatement。

pstm = conn.prepareStatement("Insert Into users values ('YourName', 'Password')");