700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > org.postgresql.util.PSQLException: An I/O error occurred while sending to the backend

org.postgresql.util.PSQLException: An I/O error occurred while sending to the backend

时间:2019-08-28 22:32:35

相关推荐

org.postgresql.util.PSQLException: An I/O error occurred while sending to the backend

PostgreSQL and Hibernate java.io.IOException: Tried to send an out-of-range integer as a 2-byte value

目录

1.报错原因

2.对入参为大数据量list的解决方法

1.报错原因

对postgresql来说,sql查询语句中的入参容量大小超出允许的最大范围(32767)(有的数据库引擎对sql长度也有限制)

2.对入参为大数据量list的解决方法

java8 Stream流处理

//按每3个一组分割private static final Integer MAX_NUMBER = 3;/*** 计算切分次数*/private static Integer countStep(Integer size) {return (size + MAX_NUMBER - 1) / MAX_NUMBER;}public static void main(String[] args) {List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7);int limit = countStep(list.size());//方法一:使用流遍历操作List<List<Integer>> mglist = new ArrayList<>();Stream.iterate(0, n -> n + 1).limit(limit).forEach(i -> {mglist.add(list.stream().skip(i * MAX_NUMBER).limit(MAX_NUMBER).collect(Collectors.toList()));});System.out.println(mglist);//方法二:获取分割后的集合List<List<Integer>> splitList = Stream.iterate(0, n -> n + 1).limit(limit).parallel().map(a -> list.stream().skip(a * MAX_NUMBER).limit(MAX_NUMBER).parallel().collect(Collectors.toList())).collect(Collectors.toList());System.out.println(splitList);}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。