ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Java -- MyBatis学习笔记5、getMapper

2021-05-08 18:03:43  阅读:185  来源: 互联网

标签:getMapper Java -- void Dao userInfoDao sqlSession userInfo public


1、为什么要使用Dao代理来实现CURD?

观察笔记4可以发现、在传统Dao层开发模式中、Dao接口实现类并没有干什么实质性的工作,它仅仅就是通过SqlSession的相关API、根据用户提供的命名空间和id值、定位到映射mapper文件中相应的SQL语句,真正对DB进行操作的工作其实是由框架通过mapper中的SQL完成的。

  • 所以

MyBatis框架就抛开了 Dao的实现类,直接定位到映射文件mapper中的相应SQL语句,对DB进行操作。这种对Dao的实现方式称为Mapper的动态代理方式。Mapper动态代理方式无需程序员实现 Dao 接口。接口是由 MyBatis 结合映射文件自动生成的动态代理实现的。

2、在MyBatis中如何使用代理、直接找到对应的mapper文件?

  • 首先、将接口实现类删除。既然使用代理直接找到接口对应的mapper文件了,所以就不需要接口实现类了。
  • 通过SqlSession调用getMapper()即可获取指定接口的实现类对象。该方法的参数为指定Dao接口类的class值。

3、代码实现:

  • 直接对上一笔记的测试类代码进行修改、首先还是声明dao接口和sqlSession对象、然后在方法里给对象赋值、如下:
    private UserInfoDao userInfoDao;
    private SqlSession sqlSession;
    @Before
    public void init() throws IOException
    {
        this.sqlSession = MyBatisUtils.getSqlSession();
        this.userInfoDao = this.sqlSession.getMapper(UserInfoDao.class);
    }
    @After
    public void finish()
    {
        //关闭selectList,释放资源
        this.sqlSession.close();
    }
  • 增删改查修改如下:
@Test
    public void selectAll()
    {
        List<UserInfo> userList = userInfoDao.selectAll();
        //循环输出集合中的结果
        userList.forEach(x -> System.out.println(x));
    }
    @Test
    public void selectUser()
    {
        UserInfo userInfo = this.userInfoDao.selectUser(2);
        System.out.println(userInfo);
    }

    @Test
    public void insert()
    {
        UserInfo userInfo = new UserInfo();
        userInfo.setName("王昭君");
        userInfo.setAge(16);
        int result = this.userInfoDao.insert(userInfo);
        sqlSession.commit();
        System.out.println(result);
    }

    @Test
    public void update()
    {
        UserInfo userInfo = new UserInfo();
        userInfo.setId(2);
        userInfo.setName("李白");
        userInfo.setAge(20);
        int result = this.userInfoDao.update(userInfo);
        sqlSession.commit();
        System.out.println(result);
    }

    @Test
    public void delete()
    {
        int result = this.userInfoDao.delete(6);
        sqlSession.commit();
        System.out.println(result);
    }

这样、通过代理的方式、直接找到对应的mapper文件里的标签和语句,更直接简单和简洁。

标签:getMapper,Java,--,void,Dao,userInfoDao,sqlSession,userInfo,public
来源: https://www.cnblogs.com/dcy521/p/14745940.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有