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

简介: 【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
1
1
0
18
分享
相关文章
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
22 0
Mybatis拦截器实现公共字段填充
通过使用MyBatis拦截器,可以实现对公共字段的自动填充,简化代码,提高开发效率。拦截器通过拦截SQL操作,在插入和更新操作时自动填充公共字段,使得开发者不再需要手动设置这些字段。本文详细介绍了实现步骤,并通过示例代码展示了具体实现方法,希望能为您的开发工作提供实用的指导和帮助。
146 13
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
5月前
|
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
174 5
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
90 3
深入理解@TableField注解的使用-MybatisPlus教程
`@TableField`注解在MyBatis-Plus中是一个非常灵活和强大的工具,能够帮助开发者精细控制实体类与数据库表字段之间的映射关系。通过合理使用 `@TableField`注解,可以实现字段名称映射、自动填充、条件查询以及自定义类型处理等高级功能。这些功能在实际开发中,可以显著提高代码的可读性和维护性。如果需要进一步优化和管理你的MyBatis-Plus应用程
352 3
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
465 1
mybatis如何仅仅查询某个表的几个字段
【10月更文挑战第19天】mybatis如何仅仅查询某个表的几个字段
201 1
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
114 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
255 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。