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

测试结果:

相关推荐
腾讯TNTWeb前端团队6 小时前
helux v5 发布了,像pinia一样优雅地管理你的react状态吧
前端·javascript·react.js
mghio7 小时前
Dubbo 中的集群容错
java·微服务·dubbo
范文杰9 小时前
AI 时代如何更高效开发前端组件?21st.dev 给了一种答案
前端·ai编程
拉不动的猪9 小时前
刷刷题50(常见的js数据通信与渲染问题)
前端·javascript·面试
拉不动的猪10 小时前
JS多线程Webworks中的几种实战场景演示
前端·javascript·面试
FreeCultureBoy10 小时前
macOS 命令行 原生挂载 webdav 方法
前端
uhakadotcom11 小时前
Astro 框架:快速构建内容驱动型网站的利器
前端·javascript·面试
uhakadotcom11 小时前
了解Nest.js和Next.js:如何选择合适的框架
前端·javascript·面试
uhakadotcom11 小时前
React与Next.js:基础知识及应用场景
前端·面试·github