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
}
后面去百度了,这不是错,出现这个问题是因为循环引用:
ps:新手小白在编码中遇到的问题在这里稍稍记录一下,欢迎各位大佬指正和补充~