美文网首页
mybatis汇总

mybatis汇总

作者: 拂清风 | 来源:发表于2019-11-14 09:34 被阅读0次

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

    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配置文件

    <?xml version="1.0" encoding="UTF-8" ?>

    <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">

      <properties resource="db.properties" />

          <setting name="mapUnderscoreToCamelCase" value="true" />

         <environments default="development">

            <environment id="development">

            <transactionManager type="JDBC" />

            <dataSource type="UNPOOLED">

                <property name="driver" value="${jdbc_driver}" />

                <property name="url" value="${jdbc_url}" />

                <property name="username" value="${jdbc_username}" />

                <property name="password" value="${jdbc_password}" />

          <mapper class="com.enjoylearning.mybatis.mapper.TUserMapper" />

    </configuration> 

    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元素属性 语句

    <insert id="insert2" parameterType="TUser">

      <selectKey  keyProperty="id" order="AFTER" resultType="int">

          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})

    </insert>

    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 id="insertSelective" parameterType="TUser">

      insert into t_user

    <trim prefix="(" suffix=")" suffixOverrides=",">

          <if test="id != null">

            id,

          <if test="userName != null">

            user_name,

          <if test="realName != null">

            real_name,

          <if test="sex != null">

            sex,

          <if test="mobile != null">

            mobile,

          <if test="email != null">

            email,

          <if test="note != null">

            note,

          <if test="positionId != null">

            position_id,

      <trim prefix="values (" suffix=")" suffixOverrides=",">

          <if test="id != null">

            #{id,jdbcType=INTEGER},

          <if test="userName != null">

            #{userName,jdbcType=VARCHAR},

          <if test="realName != null">

            #{realName,jdbcType=VARCHAR},

          <if test="sex != null">

            #{sex,jdbcType=TINYINT},

          <if test="mobile != null">

            #{mobile,jdbcType=VARCHAR},

          <if test="email != null">

            #{email,jdbcType=VARCHAR},

          <if test="note != null">

            #{note,jdbcType=VARCHAR},

          <if test="positionId != null">

            #{positionId,jdbcType=INTEGER},

    </insert>

    20:批量操作

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

    <insert id="insertForeach4Batch">

      insert into t_user (user_name, real_name,

    sex, mobile,email,note, position_id)

    values

    <foreach collection="list" separator="," item="user">

          (

    #{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}

    )

    </insert>

    (2)使用BATCH类型的excutor

    相关文章

      网友评论

          本文标题:mybatis汇总

          本文链接:https://www.haomeiwen.com/subject/shbfdctx.html