Mapper动态代理如何在Mybatis中实现

Mapper动态代理如何在Mybatis中实现?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

创新互联建站是一家专业提供罗田企业网站建设,专注与网站建设、成都网站制作H5场景定制、小程序制作等业务。10年已为罗田众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。

一、实现原理

        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的类型相同

二、Mapper.xml映射文件

       定义mapper映射文件UserMapper.xml(内容同Users.xml),需要修改namespace的值为 UserMapper接口路径。将UserMapper.xml放在classpath 下mapper目录下。 

<?xml version="1.0" encoding="UTF-8" ?> 
 
 
 
  
 
  
 
  
  
  select LAST_INSERT_ID() 
  
  insert into user(username,birthday,sex,address) 
  values(#{username},#{birthday},#{sex},#{address}) 
  
 
 

三、Mapper.java(接口文件) 

/** 
 * 用户管理mapper 
 */ 
Public interface UserMapper { 
 //根据用户id查询用户信息 
 public User findUserById(int id) throws Exception; 
 //查询用户列表 
 public List findUserByUsername(String username) throws Exception; 
 //添加用户信息 
 public void insertUser(User user)throws Exception; 
} 

接口定义有如下特点:

1、Mapper接口方法名和Mapper.xml中定义的statement的id相同
2、Mapper接口方法的输入参数类型和mapper.xml中定义的statement的parameterType的类型相同
3、Mapper接口方法的输出参数类型和mapper.xml中定义的statement的resultType的类型相同 

四、加载UserMapper.xml文件

修改sqlMapConfig.xml文件: 

 
  
  
  

五、测试  

Public class UserMapperTest extends TestCase { 
 
 private SqlSessionFactory sqlSessionFactory; 
  
 protected void setUp() throws Exception { 
  //mybatis配置文件 
  String resource = "sqlMapConfig.xml"; 
  InputStream inputStream = Resources.getResourceAsStream(resource); 
  //使用SqlSessionFactoryBuilder创建sessionFactory 
  sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); 
 } 
 
  
 Public void testFindUserById() throws Exception { 
  //获取session 
  SqlSession session = sqlSessionFactory.openSession(); 
  //获取mapper接口的代理对象 
  UserMapper userMapper = session.getMapper(UserMapper.class); 
  //调用代理对象方法 
  User user = userMapper.findUserById(1); 
  System.out.println(user); 
  //关闭session 
  session.close(); 
   
 } 
 @Test 
 public void testFindUserByUsername() throws Exception { 
  SqlSession sqlSession = sqlSessionFactory.openSession(); 
  UserMapper userMapper = sqlSession.getMapper(UserMapper.class); 
  List list = userMapper.findUserByUsername("张"); 
  System.out.println(list.size()); 
 
 } 
Public void testInsertUser() throws Exception { 
  //获取session 
  SqlSession session = sqlSessionFactory.openSession(); 
  //获取mapper接口的代理对象 
  UserMapper userMapper = session.getMapper(UserMapper.class); 
  //要添加的数据 
  User user = new User(); 
  user.setUsername("张三"); 
  user.setBirthday(new Date()); 
  user.setSex("1"); 
  user.setAddress("北京市"); 
  //通过mapper接口添加用户 
  userMapper.insertUser(user); 
  //提交 
  session.commit(); 
  //关闭session 
  session.close(); 
 } 
  
 
} 
 

六、总结 

 selectOne和selectList

         动态代理对象调用sqlSession.selectOne()和sqlSession.selectList()是根据mapper接口方法的返回值决定,如果返回list则调用selectList方法,如果返回单个对象则调用selectOne方法。

namespace

         mybatis官方推荐使用mapper代理方法开发mapper接口,程序员不用编写mapper接口实现类,使用mapper代理方法时,输入参数可以使用pojo包装对象或map对象,保证dao的通用性。

关于Mapper动态代理如何在Mybatis中实现问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


当前题目:Mapper动态代理如何在Mybatis中实现
转载注明:http://scyanting.com/article/gishos.html