Mybatis多个接口构成重载如何解决

entity:

java 复制代码
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private Integer id;
    private String username;
    private String password;
    private String phone;
    private String address;
}

dao层的接口:

java 复制代码
    List<User> selectAll();
    //方法重载 不推荐使用 调用API,不使用代理可以
    List<User> selectAll(String name);

mapper.xml文件

XML 复制代码
<?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">
<!--
    namespace属性:指定当前mapper配置文件的唯一标识符,取值为对应接口的全名
-->
<mapper namespace="org.wanho.dao.UserDAO">
    <!--
        insert:用来执行添加操作
            id属性:表示当前的方法名,取值必须与接口中的方法名相同
            parameterType属性:表示方法的参数类型
                如果参数是对象,可以使用类的全名
                如果参数是普通数据,可以使用mybatis中的别名
            标签体:编写sql语句
                使用#{xxx}表示占位符
                如果参数是对象,则xxx为对象的属性
                如果参数是普通数据,则xxx为参数名
    -->

<!--  sql:定义sql代码块,便于复用
            id属性:指定该sql代码段的唯一标识符
        -->
    <sql id="baseColumn">
        id, username, password, phone, address
    </sql>

    <sql id="baseQuery">
        select <include refid="baseColumn"/> from t_user
    </sql>


    <insert id="insert" parameterType="User" useGeneratedKeys="true" keyProperty="id">
        insert into t_user (<include refid="baseColumn"/>)
        values (null,#{username}, #{password}, #{phone}, #{address})
    </insert>

    <update id="update">
        update t_user set username = #{username},
                          password = #{password},
                          phone = #{phone},
                          address = #{address}
        where id = #{id}
    </update>
    <select id="orderByColumn">
        <include refid="baseQuery"/> where 2=2
             order by ${id} desc
    </select>

    <select id="selectAll" resultType="User">
        <include refid="baseQuery"/>
    </select>

    <select id="selectAllByName" resultType="user">
        <include refid="baseQuery"/> where username like concat('%',#{username},'%')
    </select>
</mapper>

测试类:

java 复制代码
public class UserTest02 {
    private UserDAO userDAO;
    private SqlSession session;

    @Before
    public void before() {
        session = MybatisUtil.getSession();
        userDAO = session.getMapper(UserDAO.class);
    }  

  @Test
    public void selectAll() {
        userDAO = session.getMapper(UserDAO.class);
        List<User> userList = userDAO.selectAll();
        System.out.println("userList = " + userList);
    }

    @Test
    public void selectAllByName(){
        /**
         * 当dao层的方法构成重载的时候,不能通过指定id为方法名的方式进行配置,
         * 只能使用原生的sql执行该操作
         * 解决接口中的重载 ,直接调用 sqlSession 的 API
         */
        List<Object> th = session.selectList("org.wanho.dao.UserDAO.selectAll", "th");
        th.forEach(System.out::println);
    }
}

测试结果:

相关推荐
加班是不可能的,除非双倍日工资2 小时前
css预编译器实现星空背景图
前端·css·vue3
桦说编程2 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen2 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研2 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi2 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
记忆不曾留2 小时前
Mybatis 源码解读-SqlSession 会话源码和Executor SQL操作执行器源码
mybatis·二级缓存·sqlsession会话·executor执行器·一级缓存localcache
没有bug.的程序员2 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
gnip3 小时前
vite和webpack打包结构控制
前端·javascript
excel3 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
甄超锋3 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat