0、系统环境
JDK版本:1.8
IDE:InterliJ IDEA 2019.3.3或以上
Maven版本:3.6
MyBatis版本:3.X
数据库:MySQL 5.7+
1. mybatis
1.1 mybatis本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github。
mybatis是一个基于Java的持久层框架(半自动)。持久层框架就是操作数据库的框架,对之前使用的JDBC代码进行了封装。
ORM(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术(将Java中的对象和数据库中的表关联对应起来)。理解为:Java对象与数据库表的映射管理框架。
Mybatis相当于将mapper中的入参和出参结果集封装到java的POJoQ类中,实际上Mybatis是半ORM,它鼓励开发人员自己去写sql,也正是因为sql语句要自己写,所以Mybatis是将java方法与SQL句关联起来,而没有将java对象与数据库关联起来。
1.2 MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。
MyBatis使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
可以把mybatis看做是高级的jdbc,用来解决jdbc的缺点:
1)、自动注册驱动 ;
2)、自动创建jdbc中使用的Connection, Statement,ResultSet;
3)、自动执行sql语句, 得到ResultSet;
4)、自动处理ResultSet, 把记录集中的数据转为java对象, 同时还能把java对象放入到List集合;
5)、自动关闭资源;
6)、自动实现sql语句和java代码的解耦合;
......
1.3 数据持久化:
数据持久化就是将程序的数据在持久状态和瞬时状态转化的过程;
内存存储数据特点:断电即失;
持久化方式:通过数据库(Jdbc)或io文件持久化数据。
1.4 每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。
SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。
mybatis:半ORM框架,持久层框架
mybatis.xml(定义了mybatis的基本配置和连接数据库的配置信息)
SqlSessionFactoryBuilder完成mybatis.xml配置文件的加载操作
SqlSessionFactoryBuilder --> SqlSessionFactory实例
SqlSessionFactory --> SqlSe