JavaEE SpringMyBatis是什么? 它和Hibernate的区别及如何配置MyBatis

网友投稿 254 2022-11-25


JavaEE SpringMyBatis是什么? 它和Hibernate的区别及如何配置MyBatis

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 javahttp://.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将被映射到/**,servlet不有机会抛出异常

#spring.resources.add-mappings=false

# get请求参数及表单提交数据的日期格式

spring.mvc.date-format=yyyy-MM-dd HH:mm:ss

# 应用/项目的部署路径,默认为/

#server.servlet.context-path=/lucky-draw

# SpringMVC中,DispatcherServlet的映射路径,默认为/**

#spring.mvc.servlet.path=/**

# 静态资源映射:将路径映射为/,即/static/xxx,映射为/xxx,支持多个字符串,逗号间隔

# 默认为/META-INF/resources/, /resources/, /static/, /public/

#spring.resources.static-locations=/static/,/public/

#====================要根据具体数据库配置......的部分开始====================

#druid数据库连接池配置

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

spring.datasource.url=jdbc:mysql://localhost:3306/......?useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false

spring.datasource.username=root

spring.datasource.password=......

spring.datasource.druid.initial-size=1

spring.datasource.druid.min-idle=1

spring.datasource.druid.max-active=20

spring.datasource.druid.test-on-borrow=true

#Mybatis配置

mybatis.mapper-locations=classpath:mapper/**Mapper.xml

#mybatis.type-aliases-package=frank.mapper

mybatis.configuration.map-underscore-to-camel-case=true

#mybatis.config-location=classpath:mybatis/mybatis-config.xml

#====================要根据具体数据库配置......的部分结束====================

##mapper

##mappers 多个接口时逗号隔开

##mapper.mappers=tk.mybatis.mapper.common.Mapper,tk.mybatis.mapper.common.MySqlMapper,tk.mybatis.mapper.common.IdsMapper

##mapper.notEmpty=true

##mapper.identity=MYSQL

#

##pagehelper

##数据库方言:oracle,mysql,mariadb,sqlite,hsqldb,postgresql,db2,sqlserver,informix,h2,sqlserver2012,derby

#pagehelper.helperDialect=mysql

##默认值为 false,该参数对使用 RowBounds 作为分页参数时有效。 当该参数设置为 true 时,会将 RowBounds 中的 offset 参数当成 pageNum 使用,可以用页码和页面大小两个参数进行分页。

##pagehelper.offset-as-page-num=falses

##默认值为false,该参数对使用 RowBounds 作为分页参数时有效。 当该参数设置为true时,使用 RowBounds 分页会进行 count 查询。

#pagehelper.row-bounds-with-count=true

##默认值为 false,当该参数设置为 true 时,如果 pageSize=0 或者 RowBounds.limit = 0 就会查询出全部的结果(相当于没有执行分页查询,但是返回结果仍然是 Page 类型)。

##pagehelper.page-size-zero=false

##分页合理化参数,默认值为false。当该参数设置为 true 时,pageNum<=0 时会查询第一页, pageNum>pages(超过总数时),会查询最后一页。默认false 时,直接根据参数进行查询。

#pagehelper.reasonable=true

##为了支持startPage(Object params)方法,增加了该参数来配置参数映射,用于从对象中根据属性名取值, 可以配置 pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值, 默认值为pageNum=pageNum;pageSize=pageSize;count=countSql;reasonable=reasonable;pageSizeZero=pageSizeZero。

#pagehelper.params=pageNum=pageNumber;pageSize=pageSize;count=countSql;reasonable=reasonable;

##支持通过 Mapper 接口参数来传递分页参数,默认值false,分页插件会从查询方法的参数值中,自动根据上面 params 配置的字段中取值,查找到合适的值时就会自动分页。 使用方法可以参考测试代码中的 com.github.pagehelper.test.basic 包下的 ArgumentsMapTest 和 ArgumentsObjTest。

##pagehelper.supportMethodsArguments=true

##用于控制默认不带 count 查询的方法中,是否执行 count 查询,默认 true 会执行 count 查询,这是一个全局生效的参数,多数据源时也是统一的行为。

#pagehelper.default-count=false

在resources目录下创建Generator包并且配置config.xml文件

PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"

"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

connectionURL="${spring.datasource.url}"

userId="${spring.datasource.username}"

password="${spring.datasource.password}">

connectionURL="${spring.datasource.url}"

userId="${spring.datasource.username}"

password="${spring.datasource.password}">

targetPackage="修改为实体类的包(model,在启动类的根包下)">

targetPackage="修改为实体类的包(model,在启动类的根包下)">

targetPackage="修改为xml的包(mapper)">

targetPackage="修改为xml的包(mapper)">

targetProject="修改为自己的项目名/src/test/java"

targetPackage="修改为mapper的包(在启动类的根包下)">

targetProject="修改为自己的项目名/src/test/java"

targetPackage="修改为mapper的包(在启动类的根包下)">

如果不知道路径可以自己打印一下当前项目的绝对路径

import java.io.File;

/**

* Created with IntelliJ IDEA.

* Description: If you don't work hard, you will a loser.

* User: Listen-Y.

* Date: 2020-08-21

* Time: 17:41

*/

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

总结


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:IDEA中 Getter、Setter 注解不起作用的问题如何解决
下一篇:java定义受限制的类型参数操作
相关文章

 发表评论

暂时没有评论,来抢沙发吧~