MyBatis的动态Sql查询(七)中

简介: MyBatis的动态Sql查询(七)

四. trim() 去除前后缀


<select id="findAllF3" parameterType="user" resultMap="userResultMap">
    select * from user t  <!-- 去掉第一个and -->
    <trim prefix="where" prefixOverrides="and">
      <if test="name!=null and name!=''">
        and t.name like concat('%',#{name},'%')
      </if>
      <if test="age!=null">
        and t.age>#{age}
      </if>
    </trim>
  </select>


前缀 prefix 是 where , 去除前缀注解 prefixOverrides 的and , 即去除where 后的第一个and 关键字, 这样就可以在每一个 语句后面跟上 and 而不出错了。


除了前缀之外,还有后缀 suffix 和对应的suffixOverrides 。


常见的是前缀, 去除的是 and 或者是 or.


五. choose (when,otherwise) 多分支选择


在前面的两个参数 name,age 时 查询,是多条件查询, name 和sex 是没有先后顺序的。 而在业务当中,常常是有先后顺序的。 如 name 有值,则查询name, name 无值 则去查询age, 如果age 仍然没有值,则保证 description 描述不能为空, 查询的条件之间是有明显的先后顺序的。 这个时候,就需要用 choose 了。


接口:


//有顺序的查询
  List<User> findAllF4(User user);


sql 语句: (先用以前的 1=1 模式)


<select id="findAllF4" parameterType="user" resultMap="userResultMap">
    select * from user t where 1=1
    <!--总的选择开头-->
    <choose>
      <!--对每一种情况进行判断-->
      <when test="name!=null and name!=''">
        and t.name like concat('%',#{name},'%')
      </when>
      <when test="age!=null">
        and t.age>#{age}
      </when>
      <!--所有条件都不符合,执行 otherwise -->
      <otherwise>
        and t.description is not null
      </otherwise>
    </choose>
  </select>


测试方法:


@Test
  public void findAllF4Test(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    User user=new User();
    //user.setName("蝴蝶飞");  //填写时, 不填写时不又其作为查询条件。
    //两个条件时  有一定的先后顺序。
    user.setName("蝴蝶飞");
    user.setAge(24);
    List<User> allList=userMapper.findAllF4(user);
    allList.forEach(n ->System.out.println(n));
  }


如果name 有值的话:


20190704193147830.png


如果 name 无值, age 有值的话:


20190704193222202.png


如果 name 和age 均没有值的话:


20190704193256798.png


这样,就达到了 有先后顺序的查询了。


转换成 where 语句为:


<select id="findAllF4" parameterType="user" resultMap="userResultMap">
    select * from user t
    <where>
      <choose>
        <when test="name!=null and name!=''">
          and t.name like concat('%',#{name},'%')
        </when>
        <when test="age!=null">
          and t.age>#{age}
        </when>
        <otherwise>
          and t.description is not null
        </otherwise>
      </choose>
    </where>
  </select>


六. set 更新部分字段


关于update 语句的用法,可以看第三章, 那个时候,更新都是更新全部的字段,无法进行部分字段的更新。 而以前所讲的Hibernate 只能进行全部字段的更新,这也是Hibernate 效率低的原因之一。


<update id="updateUser" parameterType="user">
    update user set name=#{name},sex=#{sex},age=#{age},description=#{description}
    where id=#{id}
  </update>


而MyBatis 通过 set 语句,很好的解决了这一点。


接口:


int updateF5(User user);


sql 语句:


<update id="updateF5" parameterType="user">
    update user 
    <set>
      <if test="name!=null and name!=''">
        name=#{name},
      </if>
      <if test="age!=null">
        age=#{age},
      </if>
      <if test="description !=null">
        description=#{description}
      </if>
    </set>
    where id=#{id}
  </update>


六.一 查询数据库更新


@Test
  public void findAllF51Test(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    User user=userMapper.getById(1);
    user.setName("部分更新字段123");
    user.setDescription("只修改部分字段");
    userMapper.updateF5(user);
    sqlSession.commit();
  }


20190704193800715.png


会将数据库中查询出来的值进行判断,如果有值,那么就进行更新,没有值,就不更新。 如果将此时的 age字段在数据库中设置为null 的话.


20190704194009750.png


再次运行的话:


20190704194039680.png


发现,这个时候 就不会更新 age 字段了。


六.二 设置对象bean 更新


@Test
  public void findAllF52Test(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    User user=new User();
    user.setId(1);
    user.setName("部分更新字段");
    user.setDescription("只修改部分字段");
    userMapper.updateF5(user);
    sqlSession.commit();
  }


这个时候,运行的话,是不会更新其他的字段的。


2019070419423173.png

相关文章
|
8天前
|
SQL NoSQL Java
Java使用sql查询mongodb
通过使用 MongoDB Connector for BI 和 JDBC,开发者可以在 Java 中使用 SQL 语法查询 MongoDB 数据库。这种方法对于熟悉 SQL 的团队非常有帮助,能够快速实现对 MongoDB 数据的操作。同时,也需要注意到这种方法的性能和功能限制,根据具体应用场景进行选择和优化。
33 9
|
29天前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
102 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
15天前
|
SQL XML Java
mybatis实现动态sql
MyBatis的动态SQL功能为开发人员提供了强大的工具来应对复杂的查询需求。通过使用 `<if>`、`<choose>`、`<foreach>`等标签,可以根据不同的条件动态生成SQL语句,从而提高代码的灵活性和可维护性。本文详细介绍了动态SQL的基本用法和实际应用示例,希望对您在实际项目中使用MyBatis有所帮助。
46 11
|
13天前
|
XML Java 数据库连接
Mybatis实现RBAC权限模型查询
通过对RBAC权限模型的理解和MyBatis的灵活使用,我们可以高效地实现复杂的权限管理功能,为应用程序的安全性和可维护性提供有力支持。
47 5
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
39 8
|
1月前
|
SQL Java 数据库连接
spring和Mybatis的各种查询
Spring 和 MyBatis 的结合使得数据访问层的开发变得更加简洁和高效。通过以上各种查询操作的详细讲解,我们可以看到 MyBatis 在处理简单查询、条件查询、分页查询、联合查询和动态 SQL 查询方面的强大功能。熟练掌握这些操作,可以极大提升开发效率和代码质量。
57 3
|
2月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
2月前
|
SQL 安全 Java
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
MyBatis-Plus 提供了一套强大的条件构造器(Wrapper),用于构建复杂的数据库查询条件。Wrapper 类允许开发者以链式调用的方式构造查询条件,无需编写繁琐的 SQL 语句,从而提高开发效率并减少 SQL 注入的风险。
39 1
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
63 4
|
2月前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。