Mybatis笔记8--使用注解开发

    技术2022-07-10  134

    1、面向接口编程

    大家之前都学过面向对象编程,也学习过接口,但是真正的开发中,很多时候我们会选择面向接口编程功

    根本原因:解耦,可拓展,提高复用,分层开发中,上层不用管具体的实现,大家都会遵守共同的标准,使得开发得容易,规范性更好

    在一个面向对象的系统中,系统的各种功能是由许许多多的不同对象协作完成的。在这种情况下,各个对象内部是如何实现自己的,对系统设计人员来讲就不那么重要了;

    而各个对象之间的协作关系则成为系统设计的关键。小到不同类之间的通信,大到各模块之间的交互,在系统设计之初都是要着重考虑的,这也是系统设计的主要工作内容。面向接口编程就是指按照这种思想来编程。

    关于接口的理解

    接口从更深层次的理解,应该定义(规范,约束)与实现(名实分离的原则)的分离接口的本身反映了系统设计人员对系统的抽象理解接口应有两类: 第一类是对一个个体的抽象,它可以对应为一个抽象类第二类是对一个个体某一方面的抽象,即形成一个抽象面;

    一个体可能有多个抽象面。抽象体与抽象面是有区别的。

    三个面向区别

    面向对象是指:我们考虑问题时,以对象为单位,考虑它的属性及方法面向了过程是指:我们考虑问题时,以一个具体的流程(事务过程)为单位,考虑它的实现接口设计与非接口设计是针对复用技术而言的,与面向对象(过程)不是一个问题,更多的体现就是对系统整体的架构

    2、使用注解开发

    注解在接口上实现

    @Select("select * from user") List<User> getUser(); 用注解来映射简单语句会使代码显得更加简洁,但对于稍微复杂一点的语句,Java 注解不仅力不从心,还会让你本就复杂的 SQL 语句更加混乱不堪。因此,如果你需要做一些很复杂的操作,最好用 XML 来映射语句。

    使用需要在核心配置文件mybatis-config.xml中绑定接口

    <!--绑定接口--> <mappers> <mapper class="com.cfeng.dao.UserMapper"/> </mappers> 测试 @Test public void getUserList(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); List<User> userList = mapper.getUser(); for (User user : userList) { System.out.println(user); } sqlSession.close(); }

    本质:反射机制实现

    底层:动态代理! Mybatis详细的执行流程(自己打断点调试搞清楚底层原理)

    Processed: 0.013, SQL: 9