PageHelper一对多查询分页解决方案

1、PageHelper插件使用相关说明参考:Mybatis简单语法

2、查询结果为一对多时用PageHelper分页解决方案:

分页插件不支持嵌套结果映射(由于嵌套结果方式会导致结果集被折叠,因此分页查询的结果在折叠后总数会减少,因此无法保证分页结果数量正确)。所有一对多关系都是懒加载的

1)方案一:代码中解决

在代码中解决:先用PageHelper将分页的基本信息查询出来,然后再循环查出每条数据需要嵌套的信息

2)方案二:使用内嵌查询
Page page= PageHelper.startPage(pojo.getPage(),pojo.getPageSize());
//只有紧跟在 PageHelper.startPage(int page,int pageSize) 方法后的【第一个】MyBatis的【查询】方法会被分页
List<AlarmExtDto> dataList=sensorAlarmDao.getAlarmExt(condition.getAlarmId());
<!--基本信息查询-->
<!--
这边遇到一个大坑,
因为我基查询和后面的嵌套查询查的是同一张表,所以刚开始的时候这个基本信息查询没有加分组,导致我后面的返回值就出现了一个很奇怪的错,返回结果贴在最下面了
-->
<select id="getBasicInfo" resultMap="basicInfo">
    select
    e.event_time,e.alarm_id
    from ib_sensor_alarm_ext e
    where e.alarm_id=#{alarmId}
    group by e.event_time
</select>

<!--结果映射-->
<resultMap id="basicInfo" type="com.ideal.saas.common.dto.alarm.AlarmExtDto">
    <result column="event_time" property="eventTime"/>
    <collection property="alarmValueList" ofType="com.ideal.saas.common.pojo.ib.tb.IbSensorAlarmExt"
                select="getAlarmValueList" column="{alarmId=alarm_id,eventTime=event_time}">
        <result column="alarm_value_type" property="alarmValueType"/>
        <result column="alarm_value" property="alarmValue"/>
    </collection>
</resultMap>

<!--内嵌查询-->
<select id="getAlarmValueList"
        parameterType="java.util.Map"
        resultType="com.ideal.saas.common.pojo.ib.tb.IbSensorAlarmExt">
    select e.alarm_value,e.alarm_value_type
    from ib_sensor_alarm_ext e
    where e.alarm_id=#{alarmId} and e.event_time=#{eventTime} and e.alarm_value_type!=2
</select>

我的请求:

{
	"page":1,  
	"pageSize":3,  
	"data":{
		"alarmId":235128
	}
}

基本查询没加分组前的错误返回:

{
    "code": 200,
    "data": {
        "data": [
            {
                "alarmValueList": [
                    {
                        "alarmValue": "https://community.nanjingdata.cn:8348/file/prd/images/pac/highTossAct/1573694608050.jpg",
                        "alarmValueType": 1
                    },
                    {
                        "alarmValue": "https://community.nanjingdata.cn:8348/file/prd/images/pac/highTossAct/1573694608060.jpg",
                        "alarmValueType": 1
                    },
                    {
                        "alarmValue": "https://community.nanjingdata.cn:8348/file/prd/images/pac/highTossAct/1573694608061.mp4",
                        "alarmValueType": 3
                    }
                ],
                "eventTime": "2019-11-14 09:23:28"
            },
            {
                "alarmValueList": [
                    {
                        "$ref": "$.data.data[0].alarmValueList[0]"
                    },
                    {
                        "$ref": "$.data.data[0].alarmValueList[1]"
                    },
                    {
                        "$ref": "$.data.data[0].alarmValueList[2]"
                    }
                ],
                "eventTime": "2019-11-14 09:23:28"
            },
            {
                "alarmValueList": [
                    {
                        "$ref": "$.data.data[0].alarmValueList[0]"
                    },
                    {
                        "$ref": "$.data.data[0].alarmValueList[1]"
                    },
                    {
                        "$ref": "$.data.data[0].alarmValueList[2]"
                    }
                ],
                "eventTime": "2019-11-14 09:23:28"
            }
        ],
        "page": 1,
        "pageSize": 3,
        "total": 18
    },
    "sid": "082c52f7-477a-4909-a168-5f7921d9480c",
    "success": true
}

后面去百度了,这不是错,出现这个问题是因为循环引用:
PageHelper一对多查询分页解决方案_第1张图片
ps:新手小白在编码中遇到的问题在这里稍稍记录一下,欢迎各位大佬指正和补充~
PageHelper一对多查询分页解决方案_第2张图片

你可能感兴趣的:(数据库,mybatis,java)