【mybatis】第二篇:@Select注解中加入字段判断

背景

因需要链表操作,所以采用了@select注解来写sql,抛弃了传统的xml形式。

1.错误性示范代码

@Select({"<script>",
         "select a.*,b.uuid,b.denoter_name as denoterName,b.spelling,b.public_name as publicName from t_denoter_qrcode a right join t_bz_denoter b on a.denoter_uuid=b.denoter_uuid ",
             "where 1=1 ",
                 "<if test='qrcodeRequest.denoterAddress !=null and qrcodeRequest.denoterAddress!="" '>" ,
                    "  and a.address like concat('%',#{qrcodeRequest.denoterAddress},'%')" ,
                 "</if> ",
                 "<if test='qrcodeRequest.denoterName !=null and qrcodeRequest.denoterName!="" '>" ,
                    " and b.denoter_name like concat('%',#{qrcodeRequest.denoterName},'%') " ,
                 "</if> ",
                 "<if test='qrcodeRequest.publicName !=null and qrcodeRequest.publicName!="" '> " ,
                    " and b.public_name like concat('%',#{qrcodeRequest.publicName},'%')" ,
                 "</if> ",
                    " <if test='qrcodeRequest.xzqhdm !=null and qrcodeRequest.xzqhdm!="" '>" ,
                    " and b.zzzz9998 like concat(#{qrcodeRequest.xzqhdm},'%') " ,
                 "</if> ",
            "</script>"})
    List<DenoterQrcodeEntity> denoterQueryList(@Param("qrcodeRequest") QrcodeRequest qrcodeRequest);

会报如下错误:

if元素类型必须后跟属性规范、">“或"/>”

 这是因为我们在写sql时候没有转义导致的!

2、正确的写法,看仔细哦

@Select({"<script>",
            "select a.*,b.uuid,b.denoter_name as denoterName,b.spelling,b.public_name as publicName from t_denoter_qrcode a right join t_bz_denoter b on a.denoter_uuid=b.denoter_uuid ",
              "where 1=1 ",
                 "<if test='qrcodeRequest.denoterAddress !=null and qrcodeRequest.denoterAddress!=\"\" '>" ,
                    "  and a.address like concat('%',#{qrcodeRequest.denoterAddress},'%')" ,
                 "</if> ",
                 "<if test='qrcodeRequest.denoterName !=null and qrcodeRequest.denoterName!=\"\" '>" ,
                    " and b.denoter_name like concat('%',#{qrcodeRequest.denoterName},'%') " ,
                 "</if> ",
                 "<if test='qrcodeRequest.publicName !=null and qrcodeRequest.publicName!=\"\" '> " ,
                    " and b.public_name like concat('%',#{qrcodeRequest.publicName},'%')" ,
                 "</if> ",
                 "<if test='qrcodeRequest.xzqhdm !=null and qrcodeRequest.xzqhdm!=\"\" '>" ,
                    " and b.zzzz9998 like concat(#{qrcodeRequest.xzqhdm},'%') " ,
                 "</if> ",
            "</script>"})
    List<DenoterQrcodeEntity> denoterQueryList(@Param("qrcodeRequest") QrcodeRequest qrcodeRequest);

 

可以看到上面写法中,在判断空字符串的时候加入了转义,这样就可以解决问题! 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

专家-郭老师

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

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

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

打赏作者

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

抵扣说明:

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

余额充值