@Select动态参数参考

今天发现一个问题,使用标签进行查询语句的拼接时,逗号和引号老处理不好,所以在此记录下,供以后参考

    @Select("<script>" +
            " select * from tb_crowd_fund_person_record a,tb_crowd_fund_info b where b.id=a.crowd_fund_info_id " +
            " <if test='activeStatus != null and activeStatus != \"\"'> "+
            "  and b.active_status=#{activeStatus} " +
            " </if> " +
            " <if test='createUser != null and createUser != \"\"'> "+
            "  and a.create_user=#{createUser} " +
            " </if> " +
            "</script>")
    List<String> findByType(Map<String,String> map);

 

在MyBatis中,可以使用@SelectProvider注解来动态拼接SQL语句。@SelectProvider注解需要指定一个Provider类,该类中包含了拼接SQL语句的方法。在Provider类中,可以使用SQL类提供的方法来进行SQL语句的拼接。具体用法可以参考MyBatis官方文档。\[2\] 例如,如果要拼接一个查询语句,可以使用@SelectProvider注解,并在Provider类中编写对应的方法来拼接SQL语句。在方法中,可以使用SQL类提供的方法来拼接查询条件。例如,可以使用SQL类的WHERE方法来拼接WHERE子句,使用SQL类的AND方法来拼接AND条件。同时,可以使用SQL类的PARAM方法来引用参数。具体的拼接方式可以根据具体的需求进行调整。\[1\] 总结起来,使用@SelectProvider注解和SQL类可以实现动态拼接SQL语句,根据不同的条件生成不同的查询语句。这样可以提高代码的灵活性和可维护性。\[2\] #### 引用[.reference_title] - *1* *2* [Mybatis的SQL语句拼接之@SelectProvider用法](https://blog.csdn.net/yuan__once/article/details/126856508)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [SQL 拼接字符串](https://blog.csdn.net/Ruishine/article/details/118671876)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

javachen__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值