使用Mapper层使用@Select注解时使用<foreach>标签报BindingException: Parameter ‘item‘ not found.

使用Mapper层使用@Select注解时使用<foreach>标签报BindingException: Parameter ‘item‘ not found.

项目场景:
使用@Select注解写SQL,里使用了<foreach>标签的item='item'

问题描述:

 @Select(
            "SELECT * FROM t_customer_info WHERE cert_type IN " +
            "<foreach item='item' index='index' collection='list' " +
            "open='(' separator=',' close=')'>" +
            "#{item}" +
            "</foreach>")
    List<CustInfo> selectByCertTypes(@Param("list") List<String> certTypes);


在foreach标签中,使用了#{item} ,报 BindingException: Parameter ‘item’ not found.

原因分析:
在@Select注解中,写带标签的复杂SQL ,需要使用“《script》” 标签

解决方案:
加上“《script》” 标签即可

 @Select("<script>" +
            "SELECT * FROM t_customer_info WHERE cert_type IN " +
            "<foreach item='item' index='index' collection='list' " +
            "open='(' separator=',' close=')'>" +
            "#{item}" +
            "</foreach>" +
            "</script>")
    List<CustInfo> selectByCertTypes(@Param("list") List<String> certTypes);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值