Mybatis-plus中自定义的sql语句调用QueryWrapper实现查询
一、引言
MP自带的条件构造器虽然很强大,有时候也避免不了写稍微复杂一点业务的sql,那么今天说说MP怎么自定义sql语句吧。
二、具体实现
使用注解实现:
在我们Mapper接口中定义自定义方法即可。
/** * @Date: 2019/6/10 14:40 * @Description</span>: User对象持久层 */ public interface UserMapper extends BaseMapper<User> { /** * 如果自定义的方法还希望能够使用MP提供的Wrapper条件构造器,则需要如下写法 * @param userWrapper */ @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文件所在位置
/** * @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); }
三、回答评论区提问
提问一:能否提供自定义Update语句与Wrapper的整合使用呢?
/** * <p> * 用户 Mapper 接口 * </p> * * @since 2019-06-14 */ public interface UserMapper extends BaseMapper<User> { /** * 自定Wrapper修改 * * @param userWrapper 条件构造器 * @param user 修改的对象参数 * @return */ int updateByMyWrapper(@Param(Constants.WRAPPER) Wrapper<User> userWrapper, @Param("user") User user); }
<?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"> <update id="updateByMyWrapper"> UPDATE user SET email = #{user.email} ${ew.customSqlSegment} </update> </mapper>
@Test public void updateByMyWrapper() { // 条件构造器 QueryWrapper<User> wrapper = new QueryWrapper(); wrapper.eq("name", "admin"); // 修改后的对象 User user = new User(); user.setEmail("Test@email.com"); userMapper.updateByMyWrapper(wrapper, user); }
Mybatis-plus的配置:
#端口号 server: port: 8088 #数据库的配置信息 spring: datasource: url: jdbc:mysql://localhost:3306/test #自己的数据库名称 username: root password: 89757 mybatis: #开启驼峰命名法 configuration: map-underscore-to-camel-case: true mybatis-plus: # xml地址 mapper-locations: classpath:mapper/*Mapper.xml # 实体扫描,多个package用逗号或者分号分隔 type-aliases-package: org.tesheng.mapper.* #自己的实体类地址 global-config: # 设置表前缀 db-config: # 配置MyBatis-Plus操作表的默认前缀 table-prefix: t_ # id生成策略自动增长 id-type: auto # sql日志打印 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl configuration: variables: # 自定义表前缀 tablePrefix: t_
mybatis: #开启驼峰命名法 configuration: map-underscore-to-camel-case: true mybatis-plus: # xml地址 mapper-locations: classpath:mapper/*Mapper.xml # 实体扫描,多个package用逗号或者分号分隔 type-aliases-package: org.tesheng.mapper.* #自己的实体类地址 configuration: # 这个配置会将执行的sql打印出来,在开发或测试的时候可以用 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl call-setters-on-nulls: true
转 :https://blog.csdn.net/shenshaoming/article/details/101099246
https://blog.csdn.net/StartedatAOP/article/details/109645540
https://www.cnblogs.com/maggieq8324/p/15239402.html