MyBatis
- MyBatis 是一个基于 Java 的持久层框架。MyBatis 提供的持久层框架包括 SQL Maps 和 Data Access Objects(DAO),它消除了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。
- MyBatis 使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。
- 目前,Java 的持久层框架产品有许多,常见的有 Hibernate 和 MyBatis。
MyBatis和hibernate的区别有哪些
首先要知道ORM框架, 简单来说就是通过实例对象的语法, 完成关系型数据库的操作的一种框架, 是 对象-关系 映射, 也就是把数据库映射成对象
开发方面
- MyBatis 是一个半自动映射的框架,因为 MyBatis 需要手动匹配 POJO、SQL 和映射关系。(半自动ORM, 需要写sql并 配置对象之间的关系)
- Hibernate 是一个全表映射的框架,只需提供 POJO 和映射关系即可。(全自动ORM 不需要写sql以java对象表示数据库关系, 自动完成sql的包装 还可以跨数据库 )
sql 优化方面
- Hibernate 不需要编写大量的 SQL,就可以完全映射,提供了日志、缓存、级联(级联比 MyBatis 强大)等特性,此外还提供 HQL(Hibernate Query Language)对 POJO 进行操作。但会多消耗性能。
- MyBatis 手动编写 SQL,支持动态 SQL、处理列表、动态生成表名、支持存储过程。工作量相对大些。 (优化工作比较方便)
不同优势
- 在技术选型时需考虑, 如果数据库的设计上会有较大的, 频繁的调整, 就是有MyBatis
- 如果需要做很多优化工作 MyBatis也是更胜一筹
实现过程
1)读取 MyBatis 配置文件:mybatis-config.xml 为 MyBatis 的全局配置文件,配置了 MyBatis 的运行环境等信息,例如数据库连接信息。
2)加载映射文件。映射文件即 SQL 映射文件,该文件中配置了操作数据库的 SQL 语句,需要在 MyBatis 配置文件 mybatis-config.xml 中加载。mybatis-config.xml 文件可以加载多个映射文件,每个文件对应数据库中的一张表。
3)构造会话工厂:通过 MyBatis 的环境等配置信息构建会话工厂 SqlSessionFactory。
4)创建会话对象:由会话工厂创建 SqlSession 对象,该对象中包含了执行 SQL 语句的所有方法。
5)Executor 执行器:MyBatis 底层定义了一个 Executor 接口来操作数据库,它将根据 SqlSession 传递的参数动态地生成需要执行的 SQL 语句,同时负责查询缓存的维护。
6)MappedStatement 对象:在 Executor 接口的执行方法中有一个 MappedStatement 类型的参数,该参数是对映射信息的封装,用于存储要映射的 SQL 语句的 id、参数等信息。
7)输入参数映射:输入参数类型可以是 Map、List 等集合类型,也可以是基本数据类型和 POJO 类型。输入参数映射过程类似于 JDBC 对 preparedStatement 对象设置参数的过程。
8)输出结果映射:输出结果类型可以是 Map、 List 等集合类型,也可以是基本数据类型和 POJO 类型。输出结果映射过程类似于 JDBC 对结果集的解析过程。
MyBatis在Spring Boot中的配置
- 创建一个SpringBoot项目
- 配置pom.xml文件
org.mybatis.spring.boot
mybatis-spring-boot-starter
2.1.1
org.mybatis.generator
mybatis-generator-core
1.3.5
mysql
mysql-connector-java
5.1.47
runtime
com.alibaba
druid-spring-boot-starter
1.1.21
在源代码路径下创建Generator
import org.mybatis.generator.api.MyBatisGenerator;
import org.mybatis.generator.config.Configuration;
import org.mybatis.generator.config.xml.ConfigurationParser;
import org.mybatis.generator.internal.DefaultShellCallback;
import java.io.File;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
public class Generator {
private static final boolean OVERWRITE = true;
private static final String CONFIG_PATH = "generator/config.xml";
public static void main(String[] args) throws Exception {
System.out.println("--------------------start generator-------------------");
System.out.println(new File("").getAbsolutePath());
List warnings = new ArrayList<>();
ClassLoader classloader = Thread.currentThread().getContextClassLoader();
InputStream is = classloader.getResourceAsStream(CONFIG_PATH);
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(is);
DefaultShellCallback callback = new DefaultShellCallback(OVERWRITE);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
warnings.forEach(System.err::println);
System.out.println("--------------------end generator-------------------");
}
}
在resources目录下配置application.properties
#debug=true
# 设置打印日志的级别,及打印sql语句
logging.level.root=ERROR
logging.level.druid.sql.Statement=ERROR
logging.level.frank=DEBUG
# 美化JSON数据格式
spring.jackson.serialization.indent-output=true
# 设置JSON数据的日期格式
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8
# JSON数据属性为null时不返回
spring.jackson.default-property-inclusion=non_null
# 找不到资源404时抛出异常
spring.mvc.throw-exception-if-no-handler-found=true
# 禁用静态资源的自动映射,如不禁用,不存在的url将被映射到
public class test {
public static void main(String[] args) {
//打印当前项目的绝对路径
System.out.println(new File("").getAbsolutePath());
}
}
在test目录下创建resources包
- 将application.properties和config.xml自己配置完毕就可以在Generator中运行
- 最后把test目录下生成的model和mapper复制到源文件的启动目录的包下 把resources目录下生成的mapper复制到源文件的resources目录下
- 在启动文件中加
@MapperScan(basePackages = "启动类的根包名.mapper")
给mapper的每个文件增加注解
@Mapper
总结
到此这篇关于JavaEE SpringMyBatis是什么? 它和Hibernate的区别及如何配置MyBatis的文章就介绍到这了,更多相关JavaEE Spring MyBatis是什么它和Hibernate的区别内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!



