Mysql查询取别名报错

一、问题背景

查询语句sql:"select b.city_unit_name as disposeunitname,a.city_event_src_name as eventsrcname from to_stat_info t,to_trans_event_src a,to_trans_unit b where t.event_src_name=a.event_src_name and t.dispose_unit_name = b.unit_name"
查询mysql中显示信息正常


image

通过程序将查询的数据信息转换成Java类时,类中的属性全部都是null


image

二、问题探索

通过mysql中查出来的信息,应该会将字段信息映射到Java类的属性中,但是好像并不是这么回事,只有深入到源码中查询一下问题所在,如下图


image

代码中是通过DAORowMapper类将mysql中查询的字段信息映射到Java类的属性中,继续深入了解这个类


image

继续向下看这个方法,下图中标出了关键的地方,为什么没有执行类中的setter方法


image

继续向下查看,就是通过反射将查询出的字段信息set到映射类的属性中
image

目前将字段信息映射到Java类中属性的关键代码地址找到了,debugger查看name值为"city_unit_name"并不是as之后的别名"disposeunitname"


image

继续深入发现这边有一个判断逻辑,通过useOldAliasBehavior走哪个业务逻辑,默认为false,通过getNameNoAliases方法获取字段名


image

查看该方法得知获取的字段名是originalName


image

debug得知ResultSetMetaData类的内部属性信息
image

从上面截图中发信name是我们需要获取的字段别名,查看下图 我们应该走上面的判断逻辑通过this.getField(column).getName()
获取字段别名,因此需要将useOldAliasBehavior设置为true


image

三、问题解决

通过查询mysql的相关资料得知获取字段的别名有两种方法,

image

一种通过方法ResultSetMetaData.getColumnLabel(),如下图


image

第二种是配置useOldAliasMetadataBehavior值为true,通过ResultSetMetaData.getColumnName()获取,该字段是通过数据库属性url来进行配置的,通过下面的配置可以将该字段赋值为true

jdbc.url=jdbc:mysql://localhost:3306/egovastat?useOldAliasMetadataBehavior=true

修改完毕之后,查询的数据信息能够映射到Java类的属性中,到这里该问题成功解决


image

四、题外话

通过这次问题探索和问题解决,感触较深。我们对于一些框架的源码应该放下敬畏之心报以平常的心态查看源码,通过查看源码来解决问题。这种方法看似困难,其实是最简单、最高效。同时,以后也要多多查看优秀的源码,学习别人的设计思想和代码习惯。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,148评论 1 32
  • 这是16年5月份编辑的一份比较杂乱适合自己观看的学习记录文档,今天18年5月份再次想写文章,发现简书还为我保存起的...
    Jenaral阅读 2,869评论 2 9
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,700评论 0 4
  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 7,857评论 5 116
  • A:你喜欢狗狗吗? B:不知道。 A:不会吧,这你都需要纠结?!喜欢就喜欢咯,不喜欢就不喜欢咯!...... B:...
    言语嫣然阅读 458评论 0 0