为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 Spring 中将 JdbcTemplate 转换为 Flux?

如何在 Spring 中将 JdbcTemplate 转换为 Flux?

料青山看我应如是 2023-04-19 17:03:12
我有一个返回List<Item>. 这些项目是由多个后续数据库调用、解析和聚合创建的(比本例中复杂得多)。如何将以下示例转换为Flux,以便流式传输我的结果,而不必先在内存中聚合所有项目?@RestControllerpublic class BookingInfoServlet {    @Autowired    private JdbcTemplate jdbc;    @GetMapping(value = "/export", produces = APPLICATION_JSON_VALUE)    public List<Item> export(String productType) {        List<Item> list = new ArrayList<>();        for (int i = 0; i < jdbc.count(); i++) {            List<String> refIds = jdbc.queryForList("SELECT ref_id FROM products where type = ? LIMIT 1000 OFFSET = ?", String.class, productType, i);            for (String id : refIds) {                Map map = jdbc.queryForMap("SELECT <anything> ... where some_id = ?, id);                Item item = new Item();                item.setName(map.get("name"));                item.setCode(map.getCode("code"));                item.set...                list.add(item);            }            //TODO how to convert to Flux here and already send the chunks back into the stream?        }        return list; //TODO how to convert to Flux?    }}第一个问题:这里我首先将第一个查询的所有结果提取到内存中,然后Item在内存中迭代并形成我的所有 s,然后返回整个列表。因此,我试图返回Flux<Item>。但是:我现在如何才能在使用时准确地返回通量JdbcTemplate?由于没有异步mysqljava 驱动程序,我可能必须对数据库查找进行分页,例如 1000,然后准备 1000 个项目并将它们流回客户端。然后获取下 1000 个项目。但是我怎样才能让他们直接进入流呢?
查看完整描述

1 回答

?
一只甜甜圈

TA贡献1836条经验 获得超5个赞

 public Flux<Item> export(String productType) {

    int pageSize = 1000;

    int count = jdbc.count();

    return Flux.range(0, count / pageSize) //page numbers

        .flatMapIterable(pageNumber ->

            jdbc.queryForList("SELECT ref_id FROM products where type = ? LIMIT ? OFFSET = ?",

                String.class,

                productType,

                pageSize,

                pageNumber * pageSize))

        .map(id -> {

          Map map = jdbc.queryForMap("SELECT <anything> ... where some_id = ?", id);

          Item item = new Item();

          //

          //

          return item;

        });

  }


查看完整回答
反对 回复 2023-04-19
  • 1 回答
  • 0 关注
  • 103 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信