求教 jdbctemplate 的 rowmapper 处理如何提前结束

2019-02-18 16:04:53 +08:00
 cstj0505
      jdbcTemplate.query(query,
          new RowMapper<Object>() {
            @Override
            public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
              String data = Utils.ResultSettoString(rs);
              kafkaTemplate.send(kafkaTopic, tableName, data);
              return true;
            }
          });

代码如上,对于查询到的每条数据转换以后发出去,但是有时候有些表比较大,执行时间长,可能需要中断什么的,这时候该怎么中断 rowmapper 的整个处理。

1528 次点击
所在节点    Java
2 条回复
lff0305
2019-02-22 14:16:35 +08:00
建议用查询条件来区分,
没法区分的话建议直接用原生的 jdbc resultset 来控制,总之如果是一个大表的话这种对数据库服务器的压力肯定会很大,
建议用多次查询每次小批量的数据
cstj0505
2019-03-01 13:23:57 +08:00
@lff0305 多谢,查询条件不受控制,最后通过主动抛异常来解决的。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/536173

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX