zoukankan      html  css  js  c++  java
  • 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;
        }
    当上帝未揭开人类的未来图景之前,人类最伟大的智慧存在于两个词中,“等待”和“希望”
  • 相关阅读:
    算法题目积累0721
    java编辑器
    java简易编辑器
    公选网站作业4_2.php
    php注册登录系统(一)-极简
    Tomcat与Web服务器、应用服务器的关系
    PHP用户登录与注册页面
    网站选修课作业(4.1)
    网站选修课作业(3.1)
    svn和ftp的区别
  • 原文地址:https://www.cnblogs.com/gosaint/p/8242166.html
Copyright © 2011-2022 走看看