1. 程式人生 > >com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; che

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; che

出現此種錯誤,我暫時遇到了兩次。
1 我的欄位的名稱和資料庫的關鍵字重合。
這裡寫圖片描述
上圖中的desc是預設降序排列的意思。
2 第二次出現的異常是我在重構程式碼階段遇到的一個bug.不過我暫時不能理解,雖然解決了錯誤。
刪除操作的程式碼如下:

 public void deleteProduct(Long id) {
        sql = "DELETE  FROM t_product WHERE id= ?";
        JDBCTemplate.templateDML(sql,id);
    }

或者如下的寫法:都是正確的。

 public void
deleteProduct(Long id) { sql = "DELETE FROM t_product WHERE id="+id; JDBCTemplate.templateDML(sql); }

但是遇上查詢一個結果的時候出現了問題:

public Product getProductById(Long id) {
        sql="SELECT * FROM  t_product  WHERE id=?";
        List<Product> list = JDBCTemplate.templateDQL(sql,id);
        return
list.size()==1?list.get(0):null; }

修改之後又可以啦;

public Product getProductById(Long id) {
        sql="SELECT * FROM  t_product  WHERE id="+id;
        List<Product> list = JDBCTemplate.templateDQL(sql);
        return list.size()==1?list.get(0):null;
    }

有點疑惑。