java.sql.ResultSetMetaData中的 getColumnName和getColumnLabel的使用;

          这个问题一般是在反射中出现,因为它们作用都是获取数据库列名;

          这个问题刚刚发现时感觉很奇怪,字段对上,又没有报异常就是没有数据,然后就开始断点看数据是什么样子;然而在封装的反射中String name = metaData.getColumnName(i)发现了问题,不是获取我给的别名;  我这里是连接了两次同一张表,然后用别名去区分它们,但不是获取了别名,获取的列名有些是一样,一脸懵逼;然后找资料.....,就发现了getColumnName的兄弟getColumnLabel;

它们的介绍如下:

         getColumnName:获取指定列的名称。

         getColumnLabel:获取指定列的建议标题,以便在打印输出和显示中使用。建议的标题通常由SQL AS子句指定。如果没  有指定SQL AS,则getColumnLabel返回的值将与getColumnName方法返回的值相同;(就是说如果有列别名,就返回列别名,没有就返回原列名)

        我的sql语句:SELECT xfb.*,zyg.YuanGongMC zyuanGongMC,yg.YuanGongMC yuanGongMC.............

        我目的是获取zyuanGongMC 和 pyuanGongMC列名,但是在获取列名的时候直接显示的列名是YuanGongMC,获取了两次YuanGongMC 然后前一个被后一个给覆盖了,导致后面获取的值是第二次的YuanGongMC值,还有一个YuanGongMC无法获取到;

使用:getColumnLabel;

         它获取的列名是zyg.YuanGongMC它的别名,赋值的时候就正常;

使用:getColumnName;

           它获取zyg.YuanGongMC 它的时候是直接获取它原本的列名,也就是YuanGongMC,因为类一次只能符一个值,所有前面的值被后面的值覆盖了,或者说根本就没有给zyuanGongMC 赋值;

         这里建议使用getColumnLabel,特别是想将ResultSet的结果映射到HashMap中的时候,尽可能的使用getColumnLabel,不然可能会出问题;

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值