美文网首页程序员
Mysql查询取别名报错

Mysql查询取别名报错

作者: 小螺钉12138 | 来源:发表于2019-02-27 22:53 被阅读5次

一、问题背景

查询语句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

四、题外话

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

相关文章

  • Mysql查询取别名报错

    一、问题背景 查询语句sql:"select b.city_unit_name as disposeunitnam...

  • MySQL入门(四):表联结

    一、MySQL别名 (一)为表取别名 在查询数据时,如果表名很长,使用起来会不方便,此时,就可以为表取一个别名,用...

  • MySql进阶语法(二)

    1:AS给列取一个别名,查询结果展示的列名就是取的别名 SELECT [列名] AS [别名] FROM [...

  • 联合查询union注意事项

    1、在使用union的子查询的时候只能给第一个取别名 其他的取别名会报语法错误 2、在子查询排序的时候 如果不...

  • hive报错

    1、HQL子查询别名问题报错:hive query failed cannot recognize input n...

  • 5.7版本之后的mysql使用group by查询VB报错

    mysql使用group by查询报错Expression #11 of SELECT list is not i...

  • DQL

    基础查询:select 查询列表 from 表名;查询列表可以是表中字段,常量值,表达式,函数取别名:as(可省略...

  • mybatis嵌套查询

    嵌套查询,第⑤行的查询条件是第⑤行第⑥行作为一个临时表,需要为临时表指定别名,这里的zd和FB都是别名,否则会报错...

  • 解决Mysql在分类查询时报1055 - Expression

    今儿在分类查询时Mysql报错,1055 - Expression #2 of SELECT list is no...

  • mysql-字段别名

    mysql中的where子句不能使用字段别名 查询姓名和年薪 查询姓名和年薪按年薪大于100000的

网友评论

    本文标题:Mysql查询取别名报错

    本文链接:https://www.haomeiwen.com/subject/mhzquqtx.html