当前位置:   article > 正文

Cursor的使用_cursor怎么使用

cursor怎么使用

1、实现类上需要添加@Transactional注解,开启事务
2、数据库连接池设置不能太小,影响其他接口访问
3、mapper的查询接口上添加 @Options(resultSetType =

@Options(resultSetType = ResultSetType.FORWARD_ONLY, fetchSize = Integer.MIN_VALUE)
Cursor<Map<String, Object>> selectLteGc(@Param(value = "province")String province);
  • 1
  • 2

4、查询到的实现类上处理数据

Cursor<Map<String, Object>> cursor = dwsParCutTaskListMapper.selectLteGc(province);
        for (Map<String, Object> map : cursor) {
            //此处处理map中的数据,一条或者一批处理,不能将数据添加到list中,加入到list中还是和加到内存中一样
        }
        return mapList;
  • 1
  • 2
  • 3
  • 4
  • 5

5、游标查询在数据库中有着广泛的应用,主要包括以下几个方面:

逐行或逐批处理数据:游标允许在查询结果集上逐行或逐批执行数据处理操作。这对于需要对每一行数据进行特定处理的场景非常有用,例如数据转换、数据清洗、复杂计算等。
浏览大型结果集:在处理大型查询结果时,不必一次性将所有数据加载到内存中,可以使用游标来逐个获取和处理数据,从而节省内存资源。
控制数据访问:游标允许在结果集中前进、后退、跳过特定行等,以灵活地控制数据的访问方式。
保存查询结果:游标可以创建一次游标结果集而重复使用若干次,比重复查询数据库要快很多。
虽然游标能遍历结果中的所有行,但请注意,游标使用时会对行加锁,可能会影响其他业务的正常进行;
当数据量大时其效率比较低效;游标其实是相当于把磁盘整体放入了内存中,如果游标数据量大则会造成内存不足,所以在数据量小时才使用游标。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/130136
推荐阅读
相关标签
  

闽ICP备14008679号