MyBatisPlus 自定义sql语句的实现

 更新时间:2019年08月14日 10:13:51   作者:IT贱男  
这篇文章主要介绍了MyBatisPlus 自定义sql语句的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、引言

Good Good Study,Day Day Up

MP自带的条件构造器虽然很强大,有时候也避免不了写稍微复杂一点业务的sql,那么那么今天说说MP怎么自定义sql语句吧。

二、配置

自定义的sql当然是写在XML文件中的啦,那么首先来定义xml文件的位置,在yml配置文件如下

mybatis-plus:
 # 如果是放在src/main/java目录下 classpath:/com/*/*/mapper/*Mapper.xml
 # 如果是放在resource目录 classpath:/mapper/**.xml
 mapper-locations: classpath:/mapper/**.xml

三、具体实现

使用注解实现:

在我们Mapper接口中定义自定义方法即可。

/**
 * @Auther: IT贱男
 * @Date: 2019/6/10 14:40
 * @Description: User对象持久层
 */
public interface UserMapper extends BaseMapper<User> {
 
  /**
   *
   * 如果自定义的方法还希望能够使用MP提供的Wrapper条件构造器,则需要如下写法
   *
   * @param userWrapper
   * @return
   */
  @Select("SELECT * FROM user ${ew.customSqlSegment}")
  List<User> selectByMyWrapper(@Param(Constants.WRAPPER) Wrapper<User> userWrapper);
 
  /**
   * 和Mybatis使用方法一致
   * @param name
   * @return
   */
  @Select("SELECT * FROM user where name = #{name}")
  List<User> selectByName(@Param("name") String name);
 
}

使用xml文件实现:

使用xml一定要指定xml文件所在位置

/**
 * @Auther: IT贱男
 * @Date: 2019/6/10 14:40
 * @Description: User对象持久层
 */
public interface UserMapper extends BaseMapper<User> {
 
  /**
   *
   * 如果自定义的方法还希望能够使用MP提供的Wrapper条件构造器,则需要如下写法
   *
   * @param userWrapper
   * @return
   */
  List<User> selectByMyWrapper(@Param(Constants.WRAPPER) Wrapper<User> userWrapper);
 
  /**
   * 和Mybatis使用方法一致
   * @param name
   * @return
   */
  List<User> selectByName(@Param("name") String name);
 
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.UserMapper">
 
  <select id="selectByName" resultType="com.example.demo.model.User">
    SELECT * FROM user where name = #{name}
  </select>
 
  <select id="selectByMyWrapper" resultType="com.example.demo.model.User">
    SELECT * FROM user ${ew.customSqlSegment}
  </select>
 
</mapper>

测试测试:

  /**
   * 自定义sql查询语句
   */
  @Test
  public void selectByMySelect() {
    List<User> users = userMapper.selectByName("王天风");
    users.forEach(System.out::println);
  }
 
  /**
   * 自定义sql使用Wrapper
   */
  @Test
  public void selectByMyWrapper() {
    QueryWrapper<User> wrapper = new QueryWrapper();
    wrapper.like("name", "雨").lt("age", 40);
    List<User> users = userMapper.selectByMyWrapper(wrapper);
    users.forEach(System.out::println);
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • mybatis使用双层<foreach>循环嵌套方式

    mybatis使用双层<foreach>循环嵌套方式

    在Mybatis中使用双层循环嵌套插入数据可以有效减少数据库IO操作,提高性能,通过在mapper.xml中定义双层集合来实现,外层集合为实体类中的集合字段,内层集合为集合字段中的另一个集合,通过这种方式,可以在业务代码中减少循环插入的次数
    2024-09-09
  • spring-core组件详解——PropertyResolver属性解决器

    spring-core组件详解——PropertyResolver属性解决器

    这篇文章主要介绍了spring-core组件详解——PropertyResolver属性解决器,需要的朋友可以参考下
    2016-05-05
  • 关于Java中的dozer对象转换问题

    关于Java中的dozer对象转换问题

    Dozer是Java Bean到Java Bean映射器,它以递归方式将数据从一个对象复制到另一个对象,这篇文章主要介绍了Java中的dozer对象转换的操作方法,需要的朋友可以参考下
    2022-08-08
  • Java本地缓存工具之LoadingCache的使用详解

    Java本地缓存工具之LoadingCache的使用详解

    缓存,在我们日常开发中是必不可少的一种解决性能问题的方法。简单的说,cache 就是为了提升系统性能而开辟的一块内存空间。本文将为大家介绍一个Java本地缓存的工具——LoadingCache,感兴趣的可以了解一下
    2021-12-12
  • 详解Spring Cloud中Hystrix 线程隔离导致ThreadLocal数据丢失

    详解Spring Cloud中Hystrix 线程隔离导致ThreadLocal数据丢失

    这篇文章主要介绍了详解Spring Cloud中Hystrix 线程隔离导致ThreadLocal数据丢失,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • java数据结构基础:单,双向链表

    java数据结构基础:单,双向链表

    这篇文章主要介绍了Java的数据解构基础,希望对广大的程序爱好者有所帮助,同时祝大家有一个好成绩,需要的朋友可以参考下,希望能给你带来帮助
    2021-07-07
  • 清理本地Maven仓库的方法示例

    清理本地Maven仓库的方法示例

    这篇文章主要介绍了清理本地Maven仓库的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • IntelliJ IDEA启动错误:插件冲突处理的解决方案

    IntelliJ IDEA启动错误:插件冲突处理的解决方案

    在使用 IntelliJ IDEA 进行开发时,我们可能会遇到各种启动错误,本文将详细介绍一种常见的错误:插件冲突,并提供解决方案,文中通过图文和代码介绍的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2025-02-02
  • 详解Java多线程编程中线程的启动、中断或终止操作

    详解Java多线程编程中线程的启动、中断或终止操作

    在Java中start和tun方法可用被用来启动线程,而用interrupt方法来中断或终止线程,以下我们就来详解Java多线程编程中线程的启动、中断或终止操作
    2016-07-07
  • Java连接数据库,及增删改查的示例

    Java连接数据库,及增删改查的示例

    这篇文章主要介绍了Java连接数据库,及增删改查的示例,帮助大家更好的利用Java处理数据,感兴趣的朋友可以了解下
    2020-10-10

最新评论