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