mybatis如何返回某列的最大值

网友投稿 1330 2022-12-26

mybatis如何返回某列的最大值

mybatis如何返回某列的最大值

mybatis返回某列的最大值

Mapper文件中sql:

select Max(id) as id from table

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;

pfQRMwsrivate 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 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

mapper接口:(我查询的是一堆结果对象,如果你查询一个,也可以传参数,自己看着改吧)

LfQRMwsist va();

这时就正常测试就可以看到结果了

重点提醒:xml文件中sql起别名as一定要对应实体类属性名,不然会查询出null(不信你可以试一下)

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mybatis 如何通过resultMap 返回long
下一篇:flutter 双向数据(flutter双向数据绑定)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~