sqlserver存储过程 返回临时表问题

1.直接使用SQL查询很慢的情况下决定使用存储过程
需要分组累加而且内容又是视图,多个表混合的,没办法使用id,那就使用临时表将视图内容放到临时表里并且使用ROW_NUMBER() over (order by 需要分组的字段) ,给他排个序

但是在使用List<Map<String,Object>>接受返回值的时候报了一个错
Could not write JSON: No serializer found for class java.io.BufferedReader and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationConfig.Feature.FAIL_ON_EMPTY_BEANS) ) (through reference chain: cn.com.whbs.pda.po.dto.DataGrid[“rows”]->java.util.ArrayList[0]->java.util.HashMap[“bz”]->net.sourceforge.jtds.jdbc.ClobImpl[“characterStream”]); nested exception is org.codehaus.jackson.map.JsonMappingException: No serializer found for class java.io.BufferedReader and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationConfig.Feature.FAIL_ON_EMPTY_BEANS) ) (through reference chain: cn.com.whbs.pda.po.dto.DataGrid[“rows”]->java.util.ArrayList[0]->java.util.HashMap[“bz”]->net.sourceforge.jtds.jdbc.ClobImpl[“characterStream”])
一看报的bz的错,后台打印一下返回的信息发现
bz=net.sourceforge.jtds.jdbc.ClobImpl@537f94ae怎么变成一个对象了,不是String 的吗
百度一搜大数据会封装成CLOB对象,找到原因了
在这里插入图片描述

解决办法
1.不要用max
2.在配置数据库连接的地方后面加上useLOBs=false
url=jdbc:jtds:sqlserver://xxx;useLOBs=false

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值