2014-07-18 38 views
0

我能夠連接到數據庫,但在執行preparedStatement插入值時遇到異常。我可以使用工作臺使用MySQL表訪問表,並從那裏插入值。表格的拼寫是正確的。使用JDBC連接到MySQL時存在SQL語法錯誤,表示該表不存在。 (但表格存在))

String insertTableSQL = "INSERT INTO source_domain_english_OY2_Jul2014(filename, seed, words, frequency, type, after_before) VALUES(?,?,?,?,?,?)"; 
. 
. 
. 
. 

preparedStatement.executeUpdate(); 

我已張貼下面

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'm_r.source_domain_english_OY2_Jul2014' doesn't exist 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:525) 
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) 
    at com.mysql.jdbc.Util.getInstance(Util.java:386) 
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1052) 
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3609) 
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3541) 
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2002) 
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2163) 
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2624) 
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2127) 
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2427) 
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2345) 
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2330) 
    at edu.albany.ils.remnd.balancedcorpus.english.GramsSearch.readPatterns(GramsSearch.java:948) 
    at edu.albany.ils.remnd.balancedcorpus.english.GramsSearch.main(GramsSearch.java:45) 
+1

你確定你在兩種情況下都使用'm_r'數據庫嗎? –

+0

您是否嘗試在輸出窗口中輸出查詢,如下面的'System.out.println(「Checking Prepared Statement:」+ preparedStatement);'然後嘗試在MySQL工作臺上運行以查看您是否收到錯誤? – John

+0

同意檢查模式(用戶)是否相同 – Kode

回答

0

堆棧跟蹤我的猜測是,你的MySQL數據庫是在Linux/Unix操作系統,在表名是區分大小寫的運行。您在代碼中將該表稱爲source_domain_english_OY2_Jul2014,但您可能在該名稱與在創建該表的腳本中使用的名稱之間存在一些小寫/大寫差異。

+0

是的,我使用的是Ubuntu。我創建了基於不同表格的表格 (創建表格2類似於table1;) – dirdir69

+0

@ user3645570問題是,您是否確定table2在您的create命令中確實是'source_domain_english_OY2_Jul2014',或者可能略有不同,例如'Source_domain_english_OY2_Jul2014' 。 – Eran

+0

我從那裏複製並粘貼,所以它是一樣的。我仔細檢查了它。難道是因爲我在代碼中使用root用戶,而在工作臺中使用了不同的用戶名(如果我在代碼中使用該用戶名,則訪問被拒絕) – dirdir69