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执行结果返回。