一、引言
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("[email protected]"); userMapper.updateByMyWrapper(wrapper, user); }
转 :https://blog.csdn.net/shenshaoming/article/details/101099246
https://blog.csdn.net/StartedatAOP/article/details/109645540
https://www.cnblogs.com/maggieq8324/p/15239402.html
标签:QueryWrapper,name,自定义,Wrapper,plus,user,Param,param From: https://www.cnblogs.com/fps2tao/p/17438712.html