(记录贴)Mybatis 数据库中用聚合函数 如何映射及赋值实体类

Posted 小样5411

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(记录贴)Mybatis 数据库中用聚合函数 如何映射及赋值实体类相关的知识,希望对你有一定的参考价值。

记录贴

找了个实习,开发中遇到一个问题记录一下,可能也是初学者会遇到的问题

SELECT basic.station_id,basic.station_name,SUM(route.road_length) AS total_kilometers,COUNT(route.id) AS total_road,COUNT(route.status=0 OR NULL) AS under_construction,COUNT(attraction.id) AS total_scenery
FROM road_road_route AS route
LEFT JOIN road_station_basic basic ON basic.route_id=route.id
LEFT JOIN road_station_attraction attraction ON attraction.route_id=basic.route_id

查询结果
在这里插入图片描述
可能也会有初学者跟我一样没反应过来,就是数据库中有对应实体知道怎么进行映射,但是这里用了聚合函数的字段呢,没有该字段对应的实体属性呀,这怎么弄?这里就要自己创建一个了叫XXXVo.java
在这里插入图片描述
这里写的字段就是数据库查出的列名对应的字段

package com.vkl.dao.vo.road;

/**
 * <p>
 * </p>
 *
 * @author yx
 * @since 2021-06-28
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value="RoadStationBasicVo对象")
public class RoadStationBasicVo extends RoadStationBasic implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "站点id")
    private Long stationId;

    @ApiModelProperty(value = "站点名称")
    private String stationName;

    @ApiModelProperty(value = "总公里数")
    private Long totalKilometers;

    @ApiModelProperty(value = "总道路数")
    private Long totalRoad;

    @ApiModelProperty(value = "在建公路数")
    private Long underConstruction;

    @ApiModelProperty(value = "景点数")
    private Long totalScenery;

}

然后就是Mybatis,将实体中的字段和数据库列名字段映射上

<resultMap id="BaseResultMap" type="com.vkl.dao.vo.road.RoadStationBasicVo">
     <id column="id" property="id"/>
     <result column="station_name" property="stationName"/>
     <result column="station_id" property="stationId"/>
     <result column="total_kilometers" property="totalKilometers"/>
     <result column="total_road" property="totalRoad"/>
     <result column="under_construction" property="underConstruction"/>
     <result column="total_scenery" property="totalScenery"/>
</resultMap>

然后在dao,service,controller写对应方法即可,用刚刚创建的Vo实体类作为返回
在这里插入图片描述
然后访问就可以看到数据了
在这里插入图片描述

以上是关于(记录贴)Mybatis 数据库中用聚合函数 如何映射及赋值实体类的主要内容,如果未能解决你的问题,请参考以下文章

是否可以在 MyBatis 中使用聚合函数

SQL Server中的聚合函数都有哪些?

如何在具有子句的聚合函数旁边选择相应的记录

如何使用聚合函数在 MySQL 查询中获取分组记录的第一条和最后一条记录?

如何使用聚合函数在 MySQL 查询中获取分组记录的第一条和最后一条记录?

sql 语句中那些是聚合函数?