mybatis cursor游标查询

在大数量查询处理时,为了避免出现OOM,可以采用cursor查询

1、dao层

import org.apache.ibatis.cursor.Cursor; //导包

//接口
Cursor<ROIReport> queryROIReportsCursor(ROIReportQuery params);
<select id="queryROIReportsCursor" resultType="com.xxx.ROIReport">
xxxxxxxxx对应自己的查询语句
</select>

service层

//service接口
Cursor<ROIReport> queryROIReportsCursor(ROIReportQuery params);

//serviceImpl
@Override
public Cursor<ROIReport> queryROIReportsCursor(ROIReportQuery params) {
	return salesMarketsMapper.queryROIReportsCursor(params);
}

controller层


//记得加上事务,不然游标在查询完就会关闭,报错
@ResponseBody
	@PostMapping("roiReportExport")
	@Transactional(readOnly = true)
	public void roiReportCursor(@RequestBody @Valid ROIReportParams params) throws ParseException {
		ROIReportQuery roiReportQuery = roiReportParams.toROIReportQuery();

		try (Cursor<ROIReport> roiReports = salesMarketsReportService.queryROIReportsCursor(roiReportQuery)) {
			Iterator<ROIReport> iterator = roiReports.iterator();
			while (iterator.hasNext()) {
				ROIReport next = iterator.next();
				System.out.println(next.getMarketName());
				System.out.println(next.getId());
				//xxxx自己业务逻辑
			}
		} catch (Exception e) {
			System.out.println(e);
		}
	}

使用cursor一定要加上事务,不然会报错:java.lang.IllegalStateException: A Cursor is already closed.

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值