详解MyBatis开发Dao层的两种方式(Mapper动态代理方式)
MyBatis开发原始Dao层请阅读我的上一篇博客:MyBatis开发Dao层的两种方式(原始Dao层开发)
接上一篇博客继续介绍MyBatis开发Dao层的第二种方式:Mapper动态代理方式
Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上一篇博客中Dao接口实现类方法。
Mapper接口开发需要遵循以下规范:
(1)Mapper.xml文件中的namespace与mapper接口的类路径相同。
(2)Mapper接口方法名和Mapper.xml中定义的每个statement的id相同
(3)Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同
(4)Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同
1、定义mapper映射文件UserMapper.xml(内容同User.xml),需要修改namespace的值为UserMapper接口路径。将UserMapper.xml放在classpath下sqlmapperr目录下。
select*fromuserwhereid=#{id} selectLAST_INSERT_ID() insertintouser(username,birthday,sex,address) values(#{username},#{birthday},#{sex},#{address}) updateusersetusername=#{username},birthday=#{birthday},sex=#{sex},address=#{address} whereid=#{id} deletefromuserwhereid=#{id}
2、UserMapper.java接口文件
packagecom.xyfer.mapper;
importcom.xyfer.po.User;
publicinterfaceUserMapper{
publicUsergetUserById(intid);//根据id值查询一个用户
publicvoidinsertUser(Useruser);//新增一个用户
publicvoidupdateUser(Useruser);//修改一个用户
publicvoiddeleteUser(intid);//删除一个用户
}
接口定义有如下特点:
(1)UserMapper接口方法名和Mapper.xml中定义的statement的id相同
(2)UserMapper接口方法的输入参数类型和mapper.xml中定义的statement的parameterType的类型相同
(3)UserMapper接口方法的输出参数类型和mapper.xml中定义的statement的resultType的类型相同
3、在SqlMapConfig.xml文件中加载UserMapper.xml文件
4、测试
packagecom.xyfer.mapper;
importstaticorg.junit.Assert.*;
importjava.io.InputStream;
importjava.util.Date;
importorg.apache.ibatis.io.Resources;
importorg.apache.ibatis.session.SqlSession;
importorg.apache.ibatis.session.SqlSessionFactory;
importorg.apache.ibatis.session.SqlSessionFactoryBuilder;
importorg.junit.Before;
importorg.junit.Test;
importcom.xyfer.po.User;
importjunit.framework.TestCase;
publicclassUserMapperTestextendsTestCase{
privateSqlSessionFactorysqlSessionFactory;
protectedvoidsetUp()throwsException{
SqlSessionFactoryBuildersessionFactoryBuilder=newSqlSessionFactoryBuilder();
InputStreaminputStream=Resources.getResourceAsStream("SqlMapConfig.xml");
sqlSessionFactory=sessionFactoryBuilder.build(inputStream);
}
@Test
publicvoidtestGetUserById(){
//获取sqlsession
SqlSessionsqlsession=sqlSessionFactory.openSession();
//获取UserMapper接口代理对象
UserMapperuserMapper=sqlsession.getMapper(UserMapper.class);
//调用代理对象方法
Useruser=userMapper.getUserById(10);
//打印结果
System.out.println(user);
//关闭sqlsession
sqlsession.close();
}
@Test
publicvoidtestInsertUser(){
//获取sqlsession
SqlSessionsqlsession=sqlSessionFactory.openSession();
//获取UserMapper接口代理对象
UserMapperuserMapper=sqlsession.getMapper(UserMapper.class);
//新建一个对象
Useruser=newUser();
user.setUsername("小谢");
user.setSex("男");
user.setBirthday(newDate());
user.setAddress("浙江省杭州市");
//调用代理对象方法
userMapper.insertUser(user);
//关闭sqlsession
sqlsession.close();
}
@Test
publicvoidtestUpdateUser(){
//获取sqlsession
SqlSessionsqlsession=sqlSessionFactory.openSession();
//获取UserMapper接口代理对象
UserMapperuserMapper=sqlsession.getMapper(UserMapper.class);
//新建一个对象
Useruser=newUser();
user.setUsername("小谢");
user.setSex("男");
user.setBirthday(newDate());
user.setAddress("上海市");
//调用代理对象方法
userMapper.updateUser(user);
//关闭sqlsession
sqlsession.close();
}
@Test
publicvoidtestDeleteUser(){
//获取sqlsession
SqlSessionsqlsession=sqlSessionFactory.openSession();
//获取UserMapper接口代理对象
UserMapperuserMapper=sqlsession.getMapper(UserMapper.class);
//调用代理对象方法
userMapper.deleteUser(6);
//关闭sqlsession
sqlsession.close();
}
}
以上步骤,完成mybatis框架以Mapper动态代理方式开发Dao层,并对数据库进行增删改查操作。
需要注意的是,上文提到的config文件夹和sqlmapper文件夹均为资源文件夹(sourcefolder),默认会加载该路径下的文件。希望对大家的学习有所帮助,也希望大家多多支持毛票票。