2016-03-30 54 views
1

我试图执行代码,但是我一直在收到错误。可能是什么问题。错误是:com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:您的SQL语法中有错误;检查与您的MySQL服务器版本相对应的手册,在'key'VALUES('davis','0704254498','0704254498',now(),'希望您有美好的一天' 1将数据插入到数据库表时出错在java中的com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException

String sql = "INSERT INTO tWebServiceSms(username,mobile,sender_id,time_sent,message_payload,status,key) VALUES(?,?,?,now(),?,?,?)"; 
    PreparedStatement stmt = null; 
    try { 
     stmt = conn.prepareStatement(sql); 
     stmt.setString(1, webServiceSmsOut.getUsername()); 
     stmt.setString(2, webServiceSmsOut.getMobile()); 
     stmt.setString(3, webServiceSmsOut.getSenderId()); 
     stmt.setString(4, webServiceSmsOut.getMessage()); 
     stmt.setInt(5, 0); 
     stmt.setString(6, webServiceSmsOut.getKey()); 
     int affected = stmt.executeUpdate(); 
     return affected == 1; 
    } catch (SQLException e) { 
     Logger.getLogger(WebServiceSmsData.class.getName()).log(Level.SEVERE, "null", e); 
     return false; 
    } finally { 
     if (stmt != null) { 
      try { 
       stmt.close(); 
      } catch (SQLException ex) { 
       Logger.getLogger(WebServiceSmsData.class.getName()).log(Level.SEVERE, null, ex); 
      } 
     } 
    } 

回答

1

因为key是MySQL中的保留关键字您收到此错误,这可能更改名称或使用反引号周围,`key`。

1

key在MySQL中的保留字用来表示一个索引,如果你想用它作为标识符名称,那么你需要用反引号(`)

相关问题