gpt4 book ai didi

mybatis如何返回某列的最大值

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 30 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章mybatis如何返回某列的最大值由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

mybatis返回某列的最大值

Mapper文件中sql:

?
1
2
3
< select id = "queryMaxId" resultType = "Integer" >
select Max(id) as id from table
< select >

resultType:以数据库对应ID属性自定义 。

SQL:

?
1
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就可以 。

如果同时出现很多个,那最简单的方法就是封装一个实体对象 。

案例:

?
1
2
3
4
5
6
7
8
9
10
11
12
/**
  * 封装的实体对象,属性对应你的查询结果字段,根据自己的情况添加
  */
@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就可以 。

举例:

?
1
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,起别名只针对求最大值,平均值等 。

举例:

?
1
2
3
< 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接口:(我查询的是一堆结果对象,如果你查询一个,也可以传参数,自己看着改吧) 。

?
1
List< MaxAndMinVA > va();

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

mybatis如何返回某列的最大值

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

mybatis如何返回某列的最大值

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我.

原文链接:https://blog.csdn.net/qq_41570658/article/details/88537292 。

最后此篇关于mybatis如何返回某列的最大值的文章就讲到这里了,如果你想了解更多关于mybatis如何返回某列的最大值的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com