首页 > 代码库 > 导出结果跟查询结果不一致

导出结果跟查询结果不一致

1、错误原因

技术分享                                                                             技术分享


2、错误原因

     上面左側图是SQL语句查询出来的结果。右側是导出Excel展示的数据。结果发现两者居然不一致


3、解决的方法

 拼接的SQL:

sql.append("SELECT  CONCAT((@rowNum := @rowNum + 1),‘‘) AS rownum,t.* FROM(");

导出中的赋值:

Map<String,Object> map=(Map<String, Object>) data.get(i);
            	HSSFRow datarow = sheet.createRow(i+1);  
                HSSFCell cell0 = datarow.createCell(0);  
                HSSFRichTextString t0 = new HSSFRichTextString((String)map.get("rownum")+"");  
                cell0.setCellValue(t0);
   rownum是数值型的。在循环中取值时,rownum变为null

Map<String,Object> map=(Map<String, Object>) data.get(i);
            	HSSFRow datarow = sheet.createRow(i+1);  
                HSSFCell cell0 = datarow.createCell(0);  
                HSSFRichTextString t0 = new HSSFRichTextString(map.get("rownum")+"");  
                cell0.setCellValue(t0);
   去掉map前的(String),并清除一下缓存


导出结果跟查询结果不一致