最佳实践中,通常一个Xml映射文件,都会写一个Dao接口与之对应,请问,这个Dao接口的工作原理是什么?Dao接口里的方法,参数不同时,方法能重载吗?

MyBatisDao浏览:1602收藏:0
答案:
Dao接口,就是人们常说的Mapper接口,---这是在基于注解的方式才会创建此接口,接口内定义了增删该查的抽象方法;
/**
* 接口: 通过注解的方法操作数据表的CRUD
* @version 2.2 2016/9/24
* @author WGS
*
*/
public interface UserMapper {
    @Insert("insert into users(name,age) values(#{name},#{age})")
    public int insertUser(User user);
    
    @Delete("delete from users where id=#{id} ")
    public int deleteUser(int id);
    
    @Update("update users set name=#{name},age=#{age} where id=#{id}")
    public int updateUser(User user);
    
    @Select("select * from users where id=#{id}")
    public User getUserById(int id);
    
    @Select("select * from users")
    public List<User> getAllUsers();
}

接口的全限名,就是映射文件中的namespace的值:
<mapper namespace="com.mybatis.test3.orderMapper">
<select id="selectUser" parameterType="int" resultType="Order">
select * from users where id=#{id}
</select>
</mapper>
接口的方法名(getUserById),就是映射文件中MappedStatement 的id值(selectUser),接口方法内的参数,就是传递给sql的参数(#{id} >>> #{id})。

Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MappedStatement,举例:com.mybatis.test2.userMapper.insertUser,可以唯一找到namespace为 com.mybatis.test2.userMapper 下面 id =insertUser 的 MappedStatement。

在Mybatis中,每一个<select>、<insert>、<update>、<delete>标签,都会被解析为一个MappedStatement对象。

2 Dao接口里的方法,是不能重载的,因为是全限名+方法名的保存和寻找策略。

3 Dao接口的工作原理是JDK动态代理,Mybatis运行时会使用JDK动态代理为Dao接口生成代理proxy对象,代理对象proxy会拦截接口方法,转而执行MappedStatement所代表的sql,然后将sql执行结果返回。