2016-03-30 40 views
1

Kodu çalıştırmaya çalışıyorum ama hata almaya devam ediyorum. Sorun ne olabilir. Hata: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: SQL sözdiziminde bir hata var; 'anahtar' yakınında kullanmak için doğru sözdizimi için MySQL sunucu sürümünüze karşılık gelen kılavuzu kontrol edin VALUES ('davis', '0704254498', '0704254498', şimdi(), 'Umarım güzel bir gün geçirirsiniz' ' key MySQL ayrılmış bir anahtar olduğu için 1Veri tablosu tablosuna veri eklenirken hata oluştu com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException java

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); 
      } 
     } 
    } 

cevap

1

Bu hatayı alıyorsanız. ya adını değiştirmek veya `etrafında key` komutu ters tırnak kullanın.

1

kelime key olan MySQL ayrılmış bir kelime var bir indeksi belirtmek için kullanılır.Eğer bir tanımlayıcı adı olarak kullanmak istiyorsanız, o zaman onu backticks (`)

İlgili konular