服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - mybatis如何返回某列的最大值

mybatis如何返回某列的最大值

2021-10-19 10:25、唐城 Java教程

这篇文章主要介绍了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

延伸 · 阅读

精彩推荐
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7472021-02-04
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16