详解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),默认会加载该路径下的文件。希望对大家的学习有所帮助,也希望大家多多支持毛票票。