MyBatis动态拼接sql,statementType="STATEMENT"使用

背景,写一个需求,展示数据的结果需要将查询出来的结果列转行,但是发现需要列转行的数据是动态的,没办法确定有多少个,所以需要动态的拼接sql处理。

MyBatis动态拼接sql,statementType=


起初设想是在MyBatis里面去动态拼接,然后尝试多次放弃了。。。

要动态拼接的sql如下,下面是静态固定的几个列,实际需要查出来循环拼接的:

MyBatis动态拼接sql,statementType=

然后选择在java控制层去处理了:

【1】java中拼接,重点标注了底色:

List flNameList = xinchouService.getZiDuanByStatus(pd);    //所有当月生效福利字段
        String str = "";
        if(flNameList.size()>0){
            for(int i=0;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中接收,重点标注了底色:


    
    


总结:

理论自己去百度,statementType="STATEMENT" '非预编译';

1.使用    statementType="STATEMENT",需要把 #{}改成 ${};

2.传入的参数注意在java中拼接的时候加上 "'" 引号;

你可能感兴趣的:(MyBatis动态拼接sql,statementType="STATEMENT"使用)