MyBatis思维导图

时间:2023-12-15 21:46:26

1、初识框架技术

2、搭建MyBatis环境

3、掌握MyBatis的核心API

4、掌握MyBatis的核心配置文件:主要用于配置数据库连接和MyBatis运行时所需的各种特性

5、掌握SQL映射文件(或者使用自动生成SQL映射文件的插件)

6、掌握MyBatis缓存

7、Dao上级操作

8、掌握动态SQL

9、掌握MyBatis框架的优缺点和其使用场合

-----------------------------------------------------------------------------------------------------------------------

---------------知识点详情

-------------------------------------------------------------

1、初识框架技术

  1.1什么是框架

      框架(Framework)是一个提供了可重用的公共结构的半成品,它成为构建新的应用程序提供了极大的便利,更提供了可重用的设计;

  1.2当前的主流框架

      1.2.1 Struts2:

            Struts2以Webwork设计思想为核心,吸收了Struts框架的部分优点,提供了一个更加整洁的基于MVC设计模式实现的Web应用程序框架。
            它引入了几个新的框架特性:从逻辑中分离出横切关注点的拦截器,减少或者消除配置文件,贯穿整个框架的强大表达式语言,支持可重用的标签API等。

            Struts2充分利用了从其他MVC框架学到的经验和教训,使整个框架更加清晰、灵活(引入了拦截器)。

      1.2.2 Hibernate:

            Hibernate是一个优秀的持久化框架(ORM),负责简化将对象数据保存到数据库中,或从数据库中读取数据并封装到对象的工作。
            Hibernate通过简单配置和编码即可替代JDBC繁琐的程序代码。

      1.2.3Spring:

            Spring是一个开源框架。它的目标是使现有的JavaEE技术更容易使用。
            它只要作为依赖注入容器和AOP实现存在,还提供了声明式事务、对DAO层的支持等简化开发等功能。
            Spring可以很方便地与SpringMVC、Struts2、Mybatis、Hibernate等框架集成。

      1.2.4Spring MVC:

            是Spring框架提供的构建Web应用程序的全功能MVC模块,属于Spring Framework的后续产品。

            它拥有高度的可配置性,支持多种视图技术,相当灵活。
            Spring整合Springmvc是无缝集成,是一个高性能的架构模式。

      1.2.5MyBatis:

          MyBatis是一个很优秀的数据持久层框架(ORM),在实体类和SQL语句之间建立映射关系,是一种半自动化的ORM实现;

            MyBatis的封装性要低于Hibernate,性能优越,并且小巧;

2、搭建MyBatis环境

  2.1什么是数据持久化:将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型的统称。

  2.2什么是ORM:

        对象关系映射(Object Relational Mapping   ORM)是一种数据持久化技术。

        它在对象模型和关系型数据库之间建立起对应关系,并且提供了一种机制,通过JavaBean对象去操作数据库表中的数据。

  2.3搭建MyBatis环境

        2.3.1、下载 jar包&部署jar包,或在pom.xml添加jar包依赖   (mybatis-3.2.2.jar)

        2.3.2、编写配置文件

        2.3.3、创建实体类(或者使用自动生成实体类的插件)

        2.3.4、创建dao接口(或者使用自动生成dao接口的插件)

        2.3.5、创建sql映射文件(或者使用自动生成sql映射文件的插件)

        2.3.6、在业务逻辑层调用

3、掌握MyBatis的核心API

  3.1SQLSessionFactoryBuilder:构建SQLSessionFactory

  3.2SqlSessionFactory:该对象可以完成对配置文件的读取factory=new SqlSessionFactoryBuilder().build(is);

  3.3SqlSession:该对象的作用是调用mapper文件进行数据库操作

4、掌握MyBatis的核心配置文件:主要用于配置数据库连接和MyBatis运行时所需的各种特性

  properties
    setting:引入log4j日志配置
    typeAliases:配置类型别名
    envrionments:配置运行的环境
    transactionManager:配置事务管理(JDBC)
    dataSource:配置数据源(POOLED:mybatis自带的数据源;JNDI:基于tomcat的数据源)
    mappers:引入映射文件,告诉mybatis去哪里找到SQL映射文件。
    mapper标签:是映射文件的根元素,只有一个属性namespace-->用于区分不同的mapper,是全局唯一

5、掌握SQL映射文件(或者使用自动生成SQL映射文件的插件)

  5.1select标签:表示查询语句

       id属性:该命名空间下唯一标识符。
         resultType属性:表示sql语句返回值类型。

        本质是相同,都是Map数据结构,但不能同时存在。

  5.2resultType与resultMap

        resultType:直接表示返回类型,包括基本数据类型和复杂数据类型。

        resultMap:应用场景一般是:数据库字段信息与对象属性不一致或者需要做复杂的联合查询,以便*控制映射结构。

6、掌握MyBatis缓存

  一级缓存:是mybatis自带的本地缓存,作用范围为session的区域,当session flush或者close之后,该session中所有的cache就会被清空;

  二级缓存:全局缓存,她超出了session范围,可以被所有的SQLSession共享,开启它只需要mybatis的核心配置文件(mybatis-config.xml)的setting中设置即可; 

      2.1) <settings>
          <setting name="cacheEnabled" value="true"/>
        </settings>
      2.2)默认是未开启二级缓存,需要手动开启。另外,它的作用域是针对mapper的namespace而言的,及只有在此namespace的查询才能共享这个cache。
        <mapper namespace="com.kgc.dao.UserMapper">
          <!---cache配置-->
          <cache eviction="fifo" flushInterval="60000" size="512" readOnly="true"/>
        </mapper>
      2.3)在mapper文件配置支持cache后,如果需要对个别查询进行调整,可以单独设置cache
        <select id="getUserList" resultType="User" useCache="true">

7、Dao上机操作

    实现多参数传递:

        @Param注解

        一般超过4个以上的参数,最好封装成对象入参 或者 map

    insert、update、delete操作要注意什么:

        7.2.1接口方法的返回值为int类型,表示执行sql语句影响的行数;

        7.2.2均没有resultType属性;

    事务处理:

        7.3.1factory.openSession(faclse); 手动提交事务;

        7.3.2session.commit(); 提交事务

        7.3.3session.rollback(); 回滚事务

    一对多的操作:使用association

    多对一的操作:使用collection

8、掌握动态SQL

  if:利用if实现简单的条件选择;

  choose(when, otherwise):相当于Java中的switch语句,通常与when和otherwise搭配使用;

  where:简化SQL语句中的where的条件判断;

  set:解决动态更新语句;

  trim:可以灵活地除去多余的关键字;

  foreach:迭代一个集合;

9、掌握MyBatis框架的优缺点和其使用场合

  9.1MyBatis框架的特点:

      9.1.1与jdbc相比,减少了50%以上的代码;

      9.1.2Mybatis相当灵活,不会对应的应用程序或者数据库的现有设计强加任何影响,

        SQL写在MXL里,从代码中彻底分离,既降低耦合度,又便于统一管理和优化

  9.2Mybatis框架的缺点

      9.2.1SQL语句的编写工作量比较大,对开发人员编写SQL语句的功底有一定的要求;

      9.2.2SQL语句依赖于数据库,导致数据库的移植性比较差,不能随意更换数据库;

  9.3框架试用场合

      9.3.1MyBatis专注于SQL本身,是一个足够灵活的DAO层解决方案;

      9.3.2对性能要求很高的项目,或者需求变化比较多的项目,如互联网项目,MyBatis将是不错的选择;

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

还在完善中。。。