今天在修改代码时遇到的一个问题
先看查询语句,这里实际上的查询语句有很多条,只列举了出错的地方的语句和出现问题的字段。
select type as type,businessrate as value
from 表
where date='2022/11/18'
group by type,rate
当然语句是没问题的,问题就出现在用这个ResultSetMetaData对象的一个getColumnName方法获取列的名字时发生问题。
因为sql的写法都是一样的,都是根据这种样式的sql查询出的结果来获取MetaData的,前面十几个sql都没有问题,直到到该sql是,控制台开始报错。
没办法好几十个循环一个一个找,终于到最后发现端倪,其他sql语句到
ResultSetMetaData.getColumeName(2).toUpperCase()
时打印的都是字段的别名也就是 “value”,而偏偏到这个sql打印的是 “businessrate”,于是导致后续
ResultSet.getObject(value)
直接报错,因为在那个结果集里我查的已经是别名了,而用getColumeName返回给我的是原始列名,这个我们看ResultSetMetaData类的该方法的介绍
获取指定列的名称
没办法,还另一种方法
ResultSetMetaData.getColumnLabel(2).toUpperCase()
获取的是你在语句中要求的该字段的名称,该方法的具体描述是
获取指定列的建议标题,以便在打印输出和显示中使用。
建议的标题通常由 SQL AS 子句指定
如果未指定 <code> AS</code>,则从
getColumnLabel 将与 getColumnName 方法返回的值相同。
即getColumnName()获得的是列名,getColumnLabel()获得的是列标题(select里的列的别名),
那么有个问题,为什么在他之前的十几个sql的样式和它差不多,为什么只有到它时被卡住?
select ifnull() as value
select (case...when...) as value
其他几个的sql那个别名的字段都是这种类型的,都不是单独的字段 as 别名,但是用getColumnName()可以获取到别名,于是试着看了看源码
这里我们具体看一下这两个方法的实现类。
这段还是可以理解的,但是每个方法里调用的com.mysql.jdbc.Field里的方法没怎么看懂,毕竟还只是一只小萌新,但是网上查阅的资料都建议用getColumnLabel(),这里只是好奇为什么这几种类型的select就能从getColumnName()获得别名