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);
    }
}

测试结果:

相关推荐
hj5914_前端新手2 小时前
javascript基础- 函数中 this 指向、call、apply、bind
前端·javascript
薛定谔的算法3 小时前
低代码编辑器项目设计与实现:以JSON为核心的数据驱动架构
前端·react.js·前端框架
Hilaku3 小时前
都2025年了,我们还有必要为了兼容性,去写那么多polyfill吗?
前端·javascript·css
yangcode3 小时前
iOS 苹果内购 Storekit 2
前端
LuckySusu3 小时前
【js篇】JavaScript 原型修改 vs 重写:深入理解 constructor的指向问题
前端·javascript
LuckySusu3 小时前
【js篇】如何准确获取对象自身的属性?hasOwnProperty深度解析
前端·javascript
LuckySusu3 小时前
【js篇】深入理解 JavaScript 作用域与作用域链
前端·javascript
LuckySusu3 小时前
【js篇】call() 与 apply()深度对比
前端·javascript
LuckySusu3 小时前
【js篇】addEventListener()方法的参数和使用
前端·javascript
该用户已不存在3 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net