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

<?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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容