0 errors 0 warnings
2018-12-24 16:52
采纳率: 0%
浏览 6.1k
已结题

MyBatis中一个Dao接口文件如何对应多个SQL映射文件(Mapper)

  在仅使用MyBatis框架的基础上(不与Spring等进行整合),我的项目中有一个接口UserDao,具体接口代码如下:

  当采用Mapper动态代理时,一般是创建一个SQL映射文件UserMapper.xml,然后将该SQL映射文件的mapper标签中的namespace设为该UserDao接口的类名,以此来实现Mapper动态代理。

  最后在测试方法中通过SqlSession类实例对象sqlSession的getMapper(UserDao.class)方法获取该接口实现类,并调用接口中的方法完成对数据表的操作。

  那么,现在我的问题是,如果现在想要两个SQL映射文件UserMapper1和UserMapper2均与UserDao接口文件相对应,该如何实现呢?

  本人Java新手,请各位大佬不吝赐教,小弟定当感激不尽。

  UserDao接口代码

package com.ccff.mybatis.dao;

import com.ccff.mybatis.model.User;

import java.util.List;

public interface IUserDao {

    //查询所有用户,以List形式返回
    public List<User> findAllUserToList();
}

  UserMapper映射文件代码

<?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.ccff.mybatis.dao.IUserDao">

    <select id="findAllUserToList" resultType="User">
        select * from user
    </select>

</mapper>

3条回答 默认 最新

相关推荐 更多相似问题