mybatis汇总

声明:本文大多数借鉴于网络,如有雷同,望见谅!!!

1:传统的jdbc相对于mybatis的弊端

    传统的jdbc代码操作量大,操作数据库至少要5步

    (1)导入sql相关的包、

    (2)注册MySQL驱动

    (3)获取一个连接

     (4)创建一个查询

      (5)从resultSet中获取数据并转化成bean

     (6)关闭连接

   业务代码和技术代码耦合

   连接资源手动关闭,带来了隐患

2:ORM是什么?

  对象关系映射(ORM Obeject  Relational Mapping),ORM模型就是数据库的表与简单Java对象(POJO)的映射模型,它主要解决数据库数据和POJO对象的相互映射

pojo对象与数据库关系

ORM带来的好处

更加贴合面向对象的编程语意

技术和业务解耦,Java程序员无需对数据库相关的知识深入了解

不用担心没有释放数据库连接资源了

3:ORM框架两大霸主


hibernate与mybatis比较

4:Mybatis是什么?

Mybatis前身是iBatis,其源于“Internet”和“ibatis”的组合,本质是一种半自动的ORM框架,除了POJO和映射关系之外,还需要编写SQL语句

mybatis

Mybatis映射文件三要素: SQL  映射规则(xml文件)   POJO 对象(Java实体类)

5:Mybatis四种生命周期

mybatis四种状态

SqlSessionFactoryBuilder:读取配置信息创建SqlSessionFactory,建造者模式,方法级别生命周期

SqlSessionFactory:创建Sqlsession,工厂单例模式,存在于程序的整个生命周期;

SqlSession:代表一次数据库连接,可以直接发送SQL执行,也可以通过调用Mapper访问数据库;线程不安全,要保证线程独享(方法级)

sql Mapper:由一个Java接口和XML文件组成,包含了要执行的SQL语句和结果集映射规则。方法级别生命周期

6:Mybatis配置

Mybatis配置

mybatis-config.xml配置文件

 

     

    

       

       

       

           

           

           

           

     

 

7:Mybatis配置 setting

setting配置
setting配置
setting配置


8:Mybatis配置 environments

(1)environment元素是配置一个数据源的开始,属性id是它的唯一标识

(2)transactionManager 元素配置数据库事务,其中type属性有三种配置方式

    jdbc,采用jdbc的方式管理事务;

   managed,采用容器的方式管理事务,在JNDI数据源中使用;

   自定义,自定义数据库事务管理办法;

(3)dataSource 元素配置数据源连接信息,type属性是连接数据库的方式配置,有四种配置方式

    UNPOOLED 非连接池方式连接

    POOLED   使用连接池连接

    JNDI  使用JNDI数据源

    自定义数据源

9:Mybatis配置 mapper

(1)用classPath下资源引用

mapper配置1

(2)用类注册方式引用

mapper配置2

(3)使用包名引入引射器名

mapper配置3

第一种方式推荐使用,类文件和mapper文件可以不需要放在一个文件夹中,xml文件也不会和java文件混合在一起

10:基于xml配置的映射器

xml文件sql

11:select元素

sql 查询语句元素

(1)自动映射

前提:SQL列名和JavaBean的属性是一致的;

自动映射等级autoMappingBehavior设置为PARTIAL,需要谨慎使用FULL;

使resultType;

如果列名和JavaBean不一致,但列名符合单词下划线分割,Java是驼峰命名法,则mapUnderscoreToCamelCase可设置为true;

(2)传递多个查询入参

使用map传递参数;可读性差,导致可维护性和可扩展性差,杜绝使用;

使用注解传递参数;直观明了,当参数较少一般小于5个的时候,建议使用;

使用Java Bean的方式传递参数;当参数大于5个的时候,建议使用;

12:resultMap元素属性

resultMap 元素是MyBatis 中最重要最强大的元素。它可以让你从90% 的 JDBCResultSets 数据提取代码中解放出来,在对复杂语句进行联合映射的时候,它很可能可以代替数千行的同等功能的代码。

 resultMap 的设计思想是,简单的语句不需要明确的结果映射,而复杂一点的语句只需要描述它们的关系就行了

resultMap元素

resultMap元素子元素

constructor- 用于在实例化类时,注入结果到构造方法中

•idArg - ID 参数;标记出作为 ID 的结果可以帮助提高整体性能

•arg - 将被注入到构造方法的一个普通结果

id – 一个 ID 结果;标记出作为 ID 的结果可以帮助提高整体性能

result – 注入到字段或 JavaBean 属性的普通结果

association– 一个复杂类型的关联;许多结果将包装成这种类型

•嵌套结果映射 – 关联可以指定为一个 resultMap 元素,或者引用一个

collection– 一个复杂类型的集合

•嵌套结果映射 – 集合可以指定为一个 resultMap 元素,或者引用一个

discriminator– 使用结果值来决定使用哪个resultMap

•case – 基于某些值的结果映射

  °嵌套结果映射 – 一个 case 也是一个映射它本身的结果,因此可以包含很多相 同的元素,或者它可以参照一个外部的 resultMap

13:id& result

id和 result 都将一个列的值映射到一个简单数据类型(字符串,整型,双精度浮点数,日期等)的属性或字段

两者之间的唯一不同是,id 表示的结果将是对象的标识属性,这会在比较对象实例时用到。

这样可以提高整体的性能,尤其是缓存和嵌套结果映射(也就是联合映射)的时候

id&result属性

14:constructor

一个pojo不存在没有参数的构造方法,就需要使用constructor;

为了通过名称来引用构造方法参数,你可以添加 @Param注解,指定参数名称的前提下,以任意顺序编写 arg 元素

constructor属性

15:insert,update 和delete

insert等属性值

16:selectKey元素(仅对insert和update有用)

selectKey元素属性
语句

 

      select LAST_INSERT_ID()

  insert into t_user (id, user_name, real_name,

sex, mobile,

email,

note, position_id)

values (#{id,jdbcType=INTEGER},

#{userName,jdbcType=VARCHAR},

#{realName,jdbcType=VARCHAR},

#{sex,jdbcType=TINYINT}, #{mobile,jdbcType=VARCHAR},

#{email,jdbcType=VARCHAR},

#{note,jdbcType=VARCHAR},

#{positionId,jdbcType=INTEGER})

17:sql元素和参数

sql元素:用来定义可重用的 SQL 代码段,可以包含在其他语句中

参数:向sql语句中传递的可变参数

           预编译 #{}:将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号,能够很大程度防止sql注入;

            传值    ${}:传入的数据直接显示生成在sql中,无法防止sql注入;

           表名、选取的列是动态的,order by和in操作, 可以考虑使用$

18:注解方式配置

注解方式就是将SQL语句直接写在接口上,对于需求比较简单的系统,效率较高。缺点在于,每次修改sql语句都要编译代码,对于复杂的sql语句可编辑性和可读性都差,一般不建议使用这种配置方式;

@Select @Results @Insert @Update  @Delete

19:动态sql元素

动态sql元素属性

trim用法

  insert into t_user

     

        id,

     

        user_name,

     

        real_name,

     

        sex,

     

        mobile,

     

        email,

     

        note,

     

        position_id,

 

     

        #{id,jdbcType=INTEGER},

     

        #{userName,jdbcType=VARCHAR},

     

        #{realName,jdbcType=VARCHAR},

     

        #{sex,jdbcType=TINYINT},

     

        #{mobile,jdbcType=VARCHAR},

     

        #{email,jdbcType=VARCHAR},

     

        #{note,jdbcType=VARCHAR},

     

        #{positionId,jdbcType=INTEGER},

20:批量操作

(1)通过foreach动态拼装SQL语句

  insert into t_user (user_name, real_name,

sex, mobile,email,note, position_id)

values

      (

#{user.userName,jdbcType=VARCHAR},

#{user.realName,jdbcType=VARCHAR},

#{user.sex,jdbcType=TINYINT},

#{user.mobile,jdbcType=VARCHAR},

#{user.email,jdbcType=VARCHAR},

#{user.note,jdbcType=VARCHAR},

#{user.positionId,jdbcType=INTEGER}

)

(2)使用BATCH类型的excutor

你可能感兴趣的:(mybatis汇总)