上篇博客中我们介绍了dao的实现,可是我们都可以看出来,在dao的实现方式中有大量重复的代码,怎么解决这个问题呢?其中一个有效的办法就是mapper代理的实现。

    首先,程序员编写mapper接口需要遵循一些开发规范,只要遵循这些规范,mybatis就可以自动生成mapper接口实现类代理对象。

    实现mapper代理的4个规范:

1、在mapper.xml中namespace等于mapper接口地址
    2、mapper.java接口中的方法名和mapper.xml中statement的id一致
    3、mapper.java接口中的方法输入参数和mapper.xml中statemetn的parameterType指定的类型一致。
    4、mapper.java接口中的方法返回值类型和mapper.xml中statement的resultType指定的类型一致。

    总结:以上规范只要是对一些重复代码的统一生成。

    在前几遍博客的基础上我们来进行mapper代理实现的测试。

    1、config下新建mapper文件夹,在mapepr文件夹下新建UserMapper.xml

    2、src下新建mapper包,在mapper包下新建usermapper.java接口

    根据开发规范,实现如下代码

    usermapper.java接口中代码实现

public interface UserMapper {

	   //根据ID查询用户
		public User findUserById(int id) throws Exception;
		
		//模糊查询用户
		public List<User> findUserByName(String name) throws Exception;
		
		//添加用户
		public void insertUser(User user) throws Exception;
		
		//删除用户
		public void deleteUser(int id) throws Exception;  
}

    UserMapper.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命名空间,作用就是对sql进行分类化管理,理解sql隔离 
注意:使用mapper代理方法开发,namespace有特殊重要的作用
-->
<mapper namespace="cn.itcast.mybatis.mapper.UserMapper">

	<!-- 在 映射文件中配置很多sql语句 -->
	<!-- 需求:通过id查询用户表的记录 -->
	<!-- 通过 select执行数据库查询
	id:标识 映射文件中的 sql
	将sql语句封装到mappedStatement对象中,所以将id称为statement的id
	parameterType:指定输入 参数的类型,这里指定int型 
	#{}表示一个占位符号
	#{id}:其中的id表示接收输入 的参数,参数名称就是id,如果输入 参数是简单类型,#{}中的参数名可以任意,可以value或其它名称
	
	resultType:指定sql输出结果 的所映射的java对象类型,select指定resultType表示将单条记录映射成的java对象。
	 -->
	<select id="findUserById" parameterType="int" resultType="cn.itcast.mybatis.po.User">
		SELECT * FROM USER WHERE id=#{value}
	</select>
	
	<!-- 根据用户名称模糊查询用户信息,可能返回多条
	resultType:指定就是单条记录所映射的java对象 类型
	${}:表示拼接sql串,将接收到参数的内容不加任何修饰拼接在sql中。
	使用${}拼接sql,引起 sql注入
	${value}:接收输入 参数的内容,如果传入类型是简单类型,${}中只能使用value
	 -->
	<select id="findUserByName" parameterType="java.lang.String" resultType="cn.itcast.mybatis.po.User">
		SELECT * FROM USER WHERE username LIKE '%${value}%'
</select>
	
	<!-- 添加用户 
	parameterType:指定输入 参数类型是pojo(包括 用户信息)
	#{}中指定pojo的属性名,接收到pojo对象的属性值,mybatis通过OGNL获取对象的属性值
	-->
	<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User">
	   insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address})
    </insert>
    
    <!-- 删除 用户
	根据id删除用户,需要输入 id值
	 -->
	<delete id="deleteUser" parameterType="java.lang.Integer">
		delete from user where id=#{id}
	</delete>
	
	<!-- 根据id更新用户
	分析:
	需要传入用户的id
	需要传入用户的更新信息
	parameterType指定user对象,包括 id和更新信息,注意:id必须存在
	#{id}:从输入 user对象中获取id属性值
	 -->
	<update id="updateUser" parameterType="cn.itcast.mybatis.po.User">
		update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address} 
		 where id=#{id}
	</update>
    
</mapper>

    在sqlmapconfig.xml中配置UserMapper.xml

<mappers>
	
	<mapper resource="mapper/UserMapper.xml" />
</mappers>

    单元测试,对userMapper.java接口生成UserMapperTest.java测试类

public class UserMapperTest {
	
	private SqlSessionFactory sqlSessionFactory;

	// 此方法shiza8itestFindUserById之前执行
	@Before
	public void setUp() throws Exception {
		// 创建sqlSessionFactory

	// mybatis配置文件
	String resource = "SqlMapConfig.xml";
	// 得到配置文件流
	InputStream inputStream = Resources.getResourceAsStream(resource);

	// 创建会话工厂,传入mybatis的配置文件信息
	sqlSessionFactory = new SqlSessionFactoryBuilder()
		.build(inputStream);
	}

	@Test
	public void testFindUserById() throws Exception {
		
		SqlSession sqlSession = sqlSessionFactory.openSession();
		
		//创建usermapper对象,mybatis自动生成mapper代理对象
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		
		//调用userMapper的方法
		
		User user = userMapper.findUserById(1);
		
		System.out.println(user);
		
		
	}

}

    至此,mapper代理的配置测试得以实现。