mongoDB easypoi导出报UnsupportedOperationException错误(mongoTemplate的find和aggregation返回结果比较)

一、简要介绍两者的用法

        find方法是mongoTemplate提供的简单条件数据查询方法,支持简单条件的查询和结果字段过滤。用法非常简单。

        aggregation方法是mongoTemplate提供的管道聚合条件查询方法,支持一些复杂条件、聚合、命令语句,用法相对复杂,返回的结果集包含的信息量也更多。

二、返回结果比较

        从返回结果可以看到,两者的返回结果都是List<T>,但略有不同,查看find方法的源码,一直追查到最里层,可以看到实际返回的就是List<T> result = new ArrayList<>()。

        查看aggregation的源代码,可以看到实际的返回就是Collection<? super V>,即new ArrayList<>()。

        至此,两者的底层接收结果的数据类型并没有太大的区别。唯一的问题在于2199行的 new AggregationResults,查看其具体实现可以看到,传入的Array List被Collections.unmodifiableList了。

三、结论/示例(UnsupportedOperationException)

        find方法返回的List是不限制任何操作的。

        aggregation方法返回的List是不支持修改的,也就是说结果集被创建后,就不能对其进行添加、删除或修改元素引用的操作,但就某个元素支持对字段的修改。否则就会报错,抛出异常。

        例如:当你通过aggregation拿到数据时,再传给EasyPoi做导出操作时,就会报错,提示传入的是一个不可被修改的列表。

java.lang.UnsupportedOperationException: null
        at java.util.Collections$unmodifiablecollection$1.remove(collections.java:1044)~[na:1.8.0_144]
        at cn.afterturn.easypoi.excel.export.ExcelExportservice.insertDataTosheet(ExcelExportservice.java:255)[easypoi-base-4.0.0.jar:na]

修改后的写法如下(加上第85行):

在使用MongoTemplate进行手动构造查询条件和返回结果的映射关系时,可以使用MongoTemplate提供的查询方法和转换方法。 手动构造查询条件: MongoTemplate提供了一系列的查询方法,可以根据不同的查询条件进行查询。例如:find()、findOne()、findDistinct()等方法,这些方法都接受一个Query对象作为查询条件参数,我们可以手动构造一个Query对象来指定查询条件。例如: ``` Query query = new Query(Criteria.where("name").is("张三")); List<User> userList = mongoTemplate.find(query, User.class); ``` 在上面的代码中,我们手动构造了一个Query对象来指定查询条件,然后使用MongoTemplate的find()方法进行查询,最后将返回的结果映射为User类的对象列表。 手动构造返回结果的映射关系: 在使用MongoTemplate进行查询时,可以通过指定返回结果类型来自动将查询结果映射为Java对象列表。例如: ``` List<User> userList = mongoTemplate.find(query, User.class); ``` 在上面的代码中,我们使用MongoTemplate的find()方法查询了MongoDB数据库,将查询结果映射为User类的对象列表。 如果不想使用自动映射,也可以手动将查询结果映射为Java对象。例如: ``` Query query = new Query(Criteria.where("name").is("张三")); Document document = mongoTemplate.findOne(query, Document.class, "user"); User user = new User(); user.setName(document.getString("name")); user.setAge(document.getInteger("age")); ``` 在上面的代码中,我们手动将查询结果Document对象中的字段映射到了User类的属性中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值