mybatis如何返回某列的最大值
mybatis返回某列的最大值
Mapper文件中sql:
<select id="queryMaxId" resultType="Integer"> select Max(id) as id from table <select>
resultType
:以数据库对应ID属性自定义
SQL
:
select * from table where id=(select MAX(id) from table )
mybatis返回最大值max,最小值min,vag,count函数和其他字段等对应接口返回值的处理方式
我们在xml文件写sql同时进行数据库查询max,min,sum,avg,count函数或其他字段,不清楚返回值怎么获取,看下去,你不会后悔O(∩_∩)O
面对这些求最大值,最小值,平均值或者夹杂着其他字段等,单个出现就正常返回Integer或者Long或着String就可以
如果同时出现很多个,那最简单的方法就是封装一个实体对象
案例:
/** * 封装的实体对象,属性对应你的查询结果字段,根据自己的情况添加 */ @Data public class MaxAndMinVA implements Serializable { private static final long serialVersionUID = 1L; private String address; private Double maxVoltage; private Double maxElectricity; private Double minVoltage; private Double minElectricity; }
在mysql中,很简单,直接正常写sql就可以
举例:
select device.address,max(va.voltage),max(va.electricity),min(va.voltage),min(va.electricity) from device left join va on device.id=va.device_id GROUP BY va.device_id
在xml文件中,需要注意:每个计算的最大值,最小值需要起别名(这个别名必须对应你的实体表属性名,不然查询出来的是null),数据库中的字段不用起别名,例如address,起别名只针对求最大值,平均值等
举例:
<select id="va" resultType="com.cn.VO.MaxAndMinVA"> select device.address,max(va.voltage) as maxVoltage,max(va.electricity) as maxElectricity,min(va.voltage) as minVoltage,min(va.electricity) as minElectricity from device left join va on device.id=va.device_id GROUP BY va.device_id </select>
mapper接口:(我查询的是一堆结果对象,如果你查询一个,也可以传参数,自己看着改吧)
List<MaxAndMinVA> va();
这时就正常测试就可以看到结果了
重点提醒:xml文件中sql起别名as一定要对应实体类属性名,不然会查询出null(不信你可以试一下)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java Comparable和Comparator对比详解
这篇文章主要介绍了Java Comparable和Comparator对比详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2019-11-11SpringBoot、Java 使用 Jsoup 解析 HTML 页面
这篇文章主要介绍了SpringBoot、Java 使用 Jsoup 解析 HTML 页面的详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-08-08SpringCloud中的Feign远程调用接口传参失败问题
这篇文章主要介绍了SpringCloud中的Feign远程调用接口传参失败问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-03-03java byte数组与int,long,short,byte的转换实现方法
下面小编就为大家带来一篇java byte数组与int,long,short,byte的转换实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-10-10
最新评论