您的位置:首页 > 数据库 > MySQL

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

2017-12-09 22:53 344 查看
出现此种错误,我暂时遇到了两次。

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


有点疑惑。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  sql 重构 异常 数据库
相关文章推荐