2013-08-02 61 views
0

嗨,我試圖插入語句,但不斷收到以下錯誤:在INSERT語句太少參數

java.sql.SQLException: [Microsoft][ODBC Microsoft Access Driver] Too few parameters. Expected 3.

這裏是我的代碼:

try { 

    Statement stmt = con.createStatement(); 

    String mySqlStatement = "INSERT INTO EntrantDetails (ID, Name, Surname, Gender, DOB ChipNum) VALUES (" + details.getIDNum()+ "," + details.getName() + "," + details.getSurname() + "," + details.getGender() + "," + details.getDOB() + "," + details.getChipNum() + ")"; 
    stmt.executeUpdate(mySqlStatement);  
    } 

    catch (Exception ex) 
    { 
     ex.printStackTrace(); 
    } 
+0

推測details.getName()返回一個字符串?如果是這樣,它應該被'引用'(並逃脫) –

+3

關閉主題,但開始使用'PreparedStatement'! – NINCOMPOOP

+0

也是DOB ChipNum的一個字段,或者是在那裏缺少逗號。如果它是一個字段是這個正確的表示,或者應該有[]圍繞它? –

回答

1

你錯過DOB之間的逗號和ChipNum。稍微注意你寫的內容。

0

你應該在DOB和ChipNum之間有逗號嗎?

0

DOB和chipnum是我想的兩個獨立的字段。如果是這樣,他們必須用逗號分隔。