• 使用 JdbcTemplate 查询数据时报错:列名无效(已解决)


    又犯了一个错误。

    争取没有下次了。

    就算再犯,也要知道去哪找答案。

    所以,记录一下,以示警戒。

    报错

    使用 JdbcTemplate 查询数据时,出现异常:

    PreparedStatementCallback; bad SQL grammar [--sql--]; nested exception is java.sql.SQLException: 列名无效

     代码大致如下:

     1 List<SomeObj> list = getJdbcTemplate().query(sql,
     2                 new RowMapper() {
     3                     public Object mapRow(ResultSet arg0, int arg1)
     4                             throws SQLException {
     5                         SomeObj row = new SomeObj();
     6 
     7                         row.setId(arg0.getString("ID"));
     8                         
     9                         return row;
    10                     }
    11                 });

    找错

    既然是 列名无效,肯定是SQL的问题了。

    于是,把SQL贴到PL/SQL 中执行,奇怪,没有报错。

    反复试了几次,都是程序报错,但直接执行SQL没问题。

    想起之前由于参数个数的问题,遇到过这样的异常:java.sql.SQLException: 无效的列索引

     于是又检查了一遍参数,没有问题。

    只能上网找找答案了。

    搜了几篇文章,没找到和这个类似的问题。

    看着看着,忽然想到,SQL中查询的列,和Java代码中要获取的列一致么?

    原来是这样

    出现异常的原因找到了:在Java代码中用到的列,SQL中没有查询。

    即,Java中用到了类似这样的代码:  row.setId(arg0.getString("COL_A"))  ,而SQL中的 SELECT 语句中没有 COL_A 这一列。

    后记:这是调整之前已有的代码,去掉了一些不必要的列,所以才导致SQL和后面需要取值的列不一致。

    新开发的话,应该不会出现这个问题。

    因为,这类应用,一般都是确定了需要哪些列,然后再去组装SQL。

  • 相关阅读:
    MYSQL索引使用
    事务的概念是什么,有哪些基本属性?
    springboot和springmvc的区别
    List、Map、Set的区别与联系
    MyBatis-动态SQL
    MyBatis-映射文件
    MyBatis操作数据库及全局配置文件
    Jmeter的基本使用
    MySQL索引优化
    MySQL索引
  • 原文地址:https://www.cnblogs.com/memory4young/p/4167044.html
Copyright © 2020-2023  润新知