ResultSetMetaData.getColumnName遇到的一个坑

今天在修改代码时遇到的一个问题

先看查询语句,这里实际上的查询语句有很多条,只列举了出错的地方的语句和出现问题的字段。

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()获得别名

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值