Mybatis框架

一、框架简介

Mybatis框架是一个基于ORM的持久化框架,Mybatis框架不是一个完整的ORM实现,而是半自动化的ORM实现。Mybatis框架的主要特点是SQL映射器机制

持久化:就是将内存中有用的数据以某种技术保存起来,并且可以再次取出来应用。也就是说,可以将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型。内存中的数据模型可以是任意数据结构或对象模型,存储数据的类型可以是XML,二进制流,关系模型等

ORM:在持久化对象上执行基本的增、删、改、查操作

二、搭建Mybatis开发环境

1.下载mybatis-3.5.1.jar

 

2.创建项目并添加所需的jar文件

3.编写MyBatis核心配置文件

4.创建实体类(POJO)

5.定义DAO层Mapper接口

6.定义SQL映射文件

7.创建测试类

 MyBatis框架优缺点:

优点: 与JDBC相比,减少了50%以上的代码量,最简单的持久化框架

SQL代码从程序代码中彻底分离,可重用

提供XML标签,支持编写动态SQL

提供映射标签,支持对象与数据库的ORM字段映射

缺点: SQL语句编写工作量大,对开发人员有一定要求

数据库移植性差

三、MyBatis基本要素

MyBatis的核心对象

1)SqlSessionFactoryBuilder

1.用过即丢,其生命周期只存在于方法体内;

2.负责构建SqlSessionFactory,并提供多个build()方法的重载

2) SqlSessionFactory

SqlSessionFactory是每个MyBatis应用的核心

作用:创建SqlSession实例 

 openSession( boolean autoCommit ) true :关闭事务控制(默认) false:开启事务控制

生命周期与应用的生命周期相同

单例 :存在于整个应用运行时,并且同时只存在一个对象实例

3) SqlSession

包含了执行SQL所需的所有方法

非线程安全,不能共享

对应一次数据库会话,会话结束必须关闭

 注意:1.关闭SqlSession非常重要,必须要 确保在finally方法体中正常关闭;

            2.一个SqlSession实例可以执行多次SQL语句


(1)、SqlSessionFactoryBuilder的最佳使用范围是什么?

        用过即丢 推荐作用域范围:局部变量

(2)、SqlSessionFactory的最佳使用范围是什么?

        生命周期与应用的生命周期相同

        最佳作用域范围:应用的全局作用域

(3)、SqlSession的最佳使用范围是什么?

        线程级

        一个request请求期间


4)配置properties元素

通过指定外部属性文件,如:jdbc.properties/database.properties

 直接配置property子节点

 【1】数据源的相关信息


【2】相应的子配置的引用。程序中只需要加载主配置文件即可


一级缓存:

1.session级别的缓存

2.默认都会有,不需要手动开启

3.线程不共享的

4.当session关闭或者flush时,session缓存清空

二级缓存:

1.sessionFactroy级别的缓存。同一个namespace内的select会被缓存

2.默认时不开启,需要手动开启

3.线程共享

4.当进行增删改的时候,缓存将被清空

二级缓存开启的步骤:

1.在mybatis的主配置文件中,开启缓存

2.在mapper中的设置缓存

 四、Mapper配置

【1】select标签。用来执行select语句,需要保证每一个select元素和接口的方法一一对应(方法名、参数和返回值)

1)id属性:用来在单个Mapper中做唯一标识,要求和接口中的方法名保持一致

2)parameterType属性 相当于方法的参数 有三种值:

1.简单的数据类型:int、string等

   <select id="getEmpList" parameterType="int" resultType="map">
       select * from  emp  where emp_id=#{id} 
    </select>

2.map 可以传入多个值,key值为map的key值

 <select id="getEmpList"  parameterType="map" resultType="map">
       select * from emp where emp_id=#{id} and dept_id=#{deptid}
    </select>

3.javaBean 可以传入多个值 key值为属性名

   <select id="getEmpList" parameterType="com.bean.Emp" resultType="map">
       select * from emp  where emp_id=#{id} and dept_id=#{deptid}
     </select>

3)resultType属性 相当于方法的返回值,一般有两种值

简单数据类型,返回单个值 

map

4) resultMap属性 主要用于返回自定义的JavaBean时

它的主要作用就是实现数据库结果集(R)和javaBean(O)之间的映射关系。所以在他的配置中既要体现R,也要体现O。在结构和数据上ORM三方都要保持统一

例如:多对一

一对多 

 update,insert,delete标签 都没有resultType属性

它们的返回值均为影响行数,int类型

增删改默认需要提交事务

@param方式

resultType与resultMap区别

resultType:

直接表示返回类型

适用于比较简单直接的数据封装场景

resultMap:

是对外部resultMap的引用

能够处理结果集字段名与实体类属性名不一致、或者需要对连接查询结果使用嵌套映射等较为复杂的问题

二者本质上都是基于Map数据结构,不能同时使用

 五、动态SQL-mybatis

if标签 可以对输入的参数进行判断,来实现动态SQL 

 

 where标签 用来简化where条件,判断是否需要and,or

where有俩作用:1.代替where字符串 2.自动判断where“紧邻的条件是否需要and,or

set标签 常用在update中 有俩作用:1.省略set字符串 2.自动判断最后的设置字段,有没有",

 trim标签 

可以替换set和where标签

   1.prefix:增加前缀

    2.prefixOverrides: 前缀自动判断省略

    3.suffix:增加后缀

    4.suffixOverrides: 后缀自动判断省略

 foreach 标签 用来迭代集合,常用来组合in

1.collection:必填。指定要循环的集合。有三种情况:

        【1】传入的参数为List时:填写list

        【2】传入的参数为数组时:填写array

        【3】传入的参数为Map,而map中有一个key值对应为集合时。填写key值

    2.open:在循环开头增加的字符串

    3.close:在循环结束增加的字符串

    4.separator:多次循环中的间隔符

    5.item:每次循环中的对象。

 choose(when\otherwise)用来做if-else的代替,类似于switch

 分页功能:基于MySql的分页关键字limit

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值