2017-04-13 70 views
0

我無法弄清楚這個錯誤在我的Java代碼中意味着什麼。什麼是我的代碼缺少索引中的IN或OUT參數:: 12

private static final String INPUT_FILE = "res/resprop.txt"; 
private static final String SELECT_MAX_ID = "SELECT MAX(ID) FROM RES"; 
private static final String INSERT_STMT = "INSERT INTO RES(ID, LEGALDESCRIPTION, ADDRESS, QUADRANT, ZONE, ASKINGPRICE, COMMENTS, AREA, BATHROOMS, BEDROOMS, GARAGE) values(?,?,?,?,?,?,?,?,?,?,?)"; 
private static final String UPDATE_STMT = "UPDATE RES SET ID = ?, LEGALDESCRIPTION = ?, ADDRESS = ?, QUADRANT = ?, ZONE = ?, ASKINGPRICE = ?, COMMENTS = ?, AREA = ?, BATHROOMS = ?, BEDROOMS = ?, GARAGE = ? where ID = ?"; 
private static final String SELECT_ID_STMT = "SELECT * FROM RES where ID = ?"; 
private static final String SELECT_LEGALDESCRIPTION_STMT = "SELECT * FROM RES where LEGALDESCRIPTION = ?"; 
private static final String SELECT_QUADRANT_STMT = "SELECT * FROM RES where QUADRANT = ?"; 
private static final String SELECT_PRICE_STMT = "SELECT * FROM RES where ASKINGPRICE = ?"; 

誤差以此以下行拋出 「INT rowCount時= pStat.executeUpdate();」

我不確定爲什麼會出現問題,我從來沒有聽說過輸入或輸出參數。另外它被稱爲java.sql.SQLException。

private boolean updatePreparedStatement(ResidentialProperty rp) 
{ 
    try 
    { 

     PreparedStatement pStat = conn.prepareStatement(UPDATE_STMT); 
     pStat.setLong(1, rp.getId()); 
     pStat.setString(2, rp.getLegalDescription()); 
     pStat.setString(3, rp.getAddress()); 
     pStat.setString(4, rp.getQuadrant()); 
     pStat.setString(5, rp.getZone()); 
     pStat.setDouble(6, rp.getAskingPrice()); 
     pStat.setString(7, rp.getComments()); 
     pStat.setDouble(8, rp.getArea()); 
     pStat.setDouble(9, rp.getBathrooms()); 
     pStat.setInt(10, rp.getBedrooms()); 
     pStat.setString(11, rp.getGarage()+""); 

     int rowCount = pStat.executeUpdate(); 

     System.out.println("row count = "+ rowCount); 
     pStat.close(); 
     return rowCount == 1; 

    } 
    catch(SQLException e) 
    { 
      e.printStackTrace(); 
    } 
    return false; 

} 

java.sql.SQLException: Missing IN or OUT parameter at index:: 12 
at oracle.jdbc.driver.OraclePreparedStatement.processCompletedBindRow(OraclePreparedStatement.java:1752) 
at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3444) 
at oracle.jdbc.driver.OraclePreparedStatement.executeUpdate(OraclePreparedStatement.java:3530) 
at oracle.jdbc.driver.OraclePreparedStatementWrapper.executeUpdate(OraclePreparedStatementWrapper.java:1350) 
at saitMLS.persistance.property.ResidentialPropertyBroker.updatePreparedStatement(ResidentialPropertyBroker.java:221) 
at saitMLS.persistance.property.ResidentialPropertyBroker.persist(ResidentialPropertyBroker.java:263) 
at saitMLS.problemDomain.property.UserInterface$1.actionPerformed(UserInterface.java:670) 
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022) 
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2348) 
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:6533) 
at javax.swing.JComponent.processMouseEvent(JComponent.java:3324) 
at java.awt.Component.processEvent(Component.java:6298) 
at java.awt.Container.processEvent(Container.java:2236) 
at java.awt.Component.dispatchEventImpl(Component.java:4889) 
at java.awt.Container.dispatchEventImpl(Container.java:2294) 
at java.awt.Component.dispatchEvent(Component.java:4711) 
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4888) 
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4525) 
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4466) 
at java.awt.Container.dispatchEventImpl(Container.java:2280) 
at java.awt.Window.dispatchEventImpl(Window.java:2746) 
at java.awt.Component.dispatchEvent(Component.java:4711) 
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:758) 
at java.awt.EventQueue.access$500(EventQueue.java:97) 
at java.awt.EventQueue$3.run(EventQueue.java:709) 
at java.awt.EventQueue$3.run(EventQueue.java:703) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:76) 
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:86) 
at java.awt.EventQueue$4.run(EventQueue.java:731) 
at java.awt.EventQueue$4.run(EventQueue.java:729) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:76) 
at java.awt.EventQueue.dispatchEvent(EventQueue.java:728) 
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201) 
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116) 
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105) 
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101) 
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93) 
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82) 
+1

向我們展示_full和exact_異常和stacktrace。此外,請計算查詢中'?'的數量,然後計算您用來填充這些'?'的項目數量,並且您可能會看到問題... – csmckelvey

+1

您的'UPDATE_STMT'包含** 12 **'?'佔位符。但是在你打電話之前你只能設置11個。 'pStat.setLong(12,rp.getId());' –

+0

非常感謝! –

回答

2

您需要到12參數傳遞到PreparedStatement的更新查詢的執行,所以它添加如下圖所示:

pStat.setLong(12, rp.getId()); 

但是,我認爲,更好的辦法是,你不「T需要在您的UPDATE_STMT再次聲明(即作爲第一個參數)設置ID,所以更改代碼,如下圖所示:

pStat.setString(1, rp.getAddress()); 
    pStat.setString(2, rp.getQuadrant()); 
    //add others here 
    pStat.setString(10, rp.getGarage()+""); 
    pStat.setLong(11, rp. getId()); 

QUERY:

UPDATE_STMT = "UPDATE RES SET LEGALDESCRIPTION = ?, 
ADDRESS = ?, QUADRANT = ?, ZONE = ?, ASKINGPRICE = ?, COMMENTS = ?, 
AREA = ?, BATHROOMS = ?, BEDROOMS = ?, GARAGE = ? where ID = ?"; 
+0

非常感謝!這工作。 –

+0

你是否明白我的觀點?你也是再次設置id,這是不必要的。 – developer

+0

此外,如果有幫助,您可以upvote並接受我的答案 – developer

相關問題