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

背景,写一个需求,展示数据的结果需要将查询出来的结果列转行,但是发现需要列转行的数据是动态的,没办法确定有多少个,所以需要动态的拼接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中拼接的时候加上 "'" 引号;

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值