背景,写一个需求,展示数据的结果需要将查询出来的结果列转行,但是发现需要列转行的数据是动态的,没办法确定有多少个,所以需要动态的拼接sql处理。
起初设想是在MyBatis里面去动态拼接,然后尝试多次放弃了。。。
要动态拼接的sql如下,下面是静态固定的几个列,实际需要查出来循环拼接的:
然后选择在java控制层去处理了:
【1】java中拼接,重点标注了底色:
List<PageData> flNameList = xinchouService.getZiDuanByStatus(pd); //所有当月生效福利字段
String str = "";
if(flNameList.size()>0){
for(int i=0;i<flNameList.size();i++){
str += "sum(case when fl_name='"+flNameList.get(i).getString("fl_name")+"' then fl_sum else 0 end ) as "+flNameList.get(i).getString("fl_name")+" ,";
}
str = str.substring(0,str.length()-1);
}
System.out.println("str:----------------------------"+str);
pd.put("str", str); //福利列转行传入后台
【2】MyBatis中接收,重点标注了底色:
<!-- sheet3_月份福利 -->
<!-- 获取当前年月每个在职人的福利数据 -->
<select id="getFLByMonthlistPage" parameterType="page" statementType="STATEMENT" resultType="pd">
select fuli.emp_name,fuli.ry_no , ${pd.str }
FROM (
SELECT c.*,d.fl_name,d.fl_status,d.fl_sum
FROM (
SELECT
ary.fuli_id,ary.ry_no,ary.nianyue,
b.birthday,b.emp_name
FROM fesher_xc_fuli_ry ary
LEFT JOIN fesher_emp b ON ary.ry_no = b.emp_id
WHERE ary.nianyue = ${pd.str2 } AND b.jobOrQuit = '在职'
) c
LEFT JOIN fesher_xc_fuli d on c.fuli_id=d.id
WHERE d.fl_status = '生效' ) fuli
group by fuli.emp_name,fuli.ry_no
[fhstart]order by fuli.ry_no ASC [fhend]
</select>
总结:
理论自己去百度,statementType="STATEMENT" '非预编译';
1.使用 statementType="STATEMENT",需要把 #{}改成 ${};
2.传入的参数注意在java中拼接的时候加上 "'" 引号;