MyBatis -> 简介

1. 定义

  • 一款支持自定义SQL存储过程高级映射持久化框架(ORM框架 -> 对象关系映射)。
    • 自定义SQL
      • 传统的JDBC中,SQL语句通过字符串表示,修改繁琐,且易出错。SQL通过定义的方式,被管理起来。
    • 阻抗不匹配
      • 客户端与服务器、数据库与服务器
      • SQL语句执行完毕后,返回一个结果集。将其转换为Java对象,将面向对象转换为面向过程。
      • 面向对象和面向过程:Web中表单提交发出请求(面向过程),Java将请求转换为Java对象去获取响应。
  • 可以通过简单的XML格式或注解进行配置,能映射基本数据元素、Map接口和POJOs到数据库中的记录。

2. MyBatis和JDBC SQL

MyBatisJDBC SQL
连接托管编码
SQL隔离/集中混合/分散
缓存两级缓存不支持
结果映射自动映射硬编码
维护性
  • JDBC SQL中SQL语句与Java代码是混合在一起的,分散在各个地方。
  • 缓存:提高访问效率

3.MyBatis的核心概念

3.1 核心类

3.1.1 SqlSessionFactoryBuilder
  • 该类可在任何时候创建、使用、销毁。由于一旦创造了SqlSessionFactory就不需要该类,因此该类的作用域最好为一个方法体内部。
3.1.2 SqlSessionFactory
  • 该类一旦创建,将会存在于应用程序的整个生命周期,因此该类的作用域最好为一个应用的生命周期。
3.1.3 SqlSession
  • 这是一个实例,非共享,线程不安全。通过该实例来对数据库进行操作,不使用时及时关闭。
3.1.4 Mapper interface
  • 用于创建绑定映射语句,从SqlSession获取Mapper实例,该类的作用域最好为一个方法体内部,使用完后销毁。

3.2 SQL映射

  • 两种方式
    • 基于XML
      • 维护性、阅读性强
      • 集中管理SQL
    • 基于Java
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值