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

 更新时间:2020年08月22日 09:04:55   作者:Listen-Y  
这篇文章主要介绍了JavaEE Spring MyBatis是什么? 它和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文件
<!-- =================要添加的部分开始================== -->

    <dependency>
      <groupId>org.mybatis.spring.boot</groupId>
      <artifactId>mybatis-spring-boot-starter</artifactId>
      <version>2.1.1</version>
    </dependency>

    <!-- Mybatis代码生成工具 -->
    <dependency>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-core</artifactId>
      <version>1.3.5</version>
    </dependency>

    <!-- mysql-connector-java: mysql数据库驱动包
                在编译时没有直接使用,但是运行时需要,所以使用
                scope runtime -->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.47</version>
      <scope>runtime</scope>
    </dependency>

    <!-- druid-spring-boot-starter: 阿里Druid数据库连接池,同样的运行时需要 -->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid-spring-boot-starter</artifactId>
      <version>1.1.21</version>
    </dependency>
		
		<!-- =================要添加的部分结束================== -->

在源代码路径下创建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<String> 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文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
    PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
    "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

<generatorConfiguration>
  <properties resource="application.properties" />

  <context id="Mysql" targetRuntime="MyBatis3" defaultModelType="flat">

    <property name="javaFileEncoding" value="UTF-8"/>

    <commentGenerator>
      <property name="suppressDate" value="true"/>
      <property name="suppressAllComments" value="true" />
      <property name="addRemarkComments" value="true"/>
    </commentGenerator>

    <jdbcConnection driverClass="${spring.datasource.driver-class-name}"
            connectionURL="${spring.datasource.url}"
            userId="${spring.datasource.username}"
            password="${spring.datasource.password}">
      <property name="useInformationSchema" value="true" />
    </jdbcConnection>

    <!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,
        为 true时把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal -->
    <javaTypeResolver>
      <property name="forceBigDecimals" value="false" />
    </javaTypeResolver>

    <!--MyBatis 生成器只需要生成 Model-->
    <javaModelGenerator targetProject="修改为自己的项目名/src/test/java"
              targetPackage="修改为实体类的包(model,在启动类的根包下)">
<!--      <property name="rootClass" value="修改为实体类的父类"/>-->
    </javaModelGenerator>

    <!--mybatis 的xml文件地址-->
    <sqlMapGenerator targetProject="修改为自己的项目名/src/test/resources"
             targetPackage="修改为xml的包(mapper)">
      <property name="enableSubPackages" value="true"/>
    </sqlMapGenerator>

    <!--mybatis的mapper接口-->
    <javaClientGenerator type="XMLMAPPER"
               targetProject="修改为自己的项目名/src/test/java"
               targetPackage="修改为mapper的包(在启动类的根包下)">
      <property name="enableSubPackages" value="true"/>
<!--      <property name="rootInterface" value="修改为mapper的父接口"/>-->
    </javaClientGenerator>

    <!-- 需要生成的表,%表示模糊匹配,也可以指定具体的表名 -->
<!--    <table tableName="%"-->
<!--        enableCountByExample="false"-->
<!--        enableDeleteByExample="false"-->
<!--        enableSelectByExample="false"-->
<!--        enableUpdateByExample="false"-->
<!--    >-->
    <table tableName="%">
      <!-- insert方法通过自增主键插入数据后,主键值是否设置到对象属性中 -->
      <!--      <generatedKey column="id" sqlStatement="JDBC"/>-->
      <generatedKey column="id" sqlStatement="Mysql" identity="true" />
    </table>
    <!--    <table tableName="user">-->
    <!--      <generatedKey column="id" sqlStatement="Mysql" identity="true" />-->
    <!--    </table>-->
  </context>
</generatorConfiguration>

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

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

总结

到此这篇关于JavaEE SpringMyBatis是什么? 它和Hibernate的区别及如何配置MyBatis的文章就介绍到这了,更多相关JavaEE Spring MyBatis是什么它和Hibernate的区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot项目实现日志打印SQL的常用方法(包括SQL语句和参数)

    SpringBoot项目实现日志打印SQL的常用方法(包括SQL语句和参数)

    有时候遇到问题需要根据我们编写的SQL进行分析,但如果不进行一些开发或者配置的话,这些SQL是不会打印到控制台的,它们默认是隐藏的。下面给大家介绍几种常用的方法,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • 详解使用Maven开发Web应用详细步骤

    详解使用Maven开发Web应用详细步骤

    这篇文章主要介绍了详解使用Maven开发Web应用详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • 详解Huffman编码算法之Java实现

    详解Huffman编码算法之Java实现

    Huffman编码是一种编码方式,常用于无损压缩。本文只介绍用Java语言来实现该编码方式的算法和数据结构。有兴趣的可以了解一下。
    2016-12-12
  • 将本地JAR文件手动添加到Maven本地仓库的实现过程

    将本地JAR文件手动添加到Maven本地仓库的实现过程

    在Java开发中,使用Maven作为项目管理工具已经成为了主流的选择,Maven提供了强大的依赖管理功能,可以轻松地下载和管理项目所需的库和工具,在某些情况下,你可能会需要将本地下载的JAR文件手动添加到Maven的本地仓库中,这篇博客将详细介绍如何实现这一过程
    2024-10-10
  • idea新建Springboot项目,设置默认maven和jdk版本方式

    idea新建Springboot项目,设置默认maven和jdk版本方式

    这篇文章主要介绍了idea新建Springboot项目,设置默认maven和jdk版本方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 基于Java实现连连看游戏的示例代码

    基于Java实现连连看游戏的示例代码

    连连看游戏顾名思义就是找出具有关联关系的事物并进行相应处理。本文将用java语言实现这一经典游戏,采用了swing技术进行了界面化处理,感兴趣的可以了解一下
    2022-09-09
  • 详解SpringCloud微服务之Rest

    详解SpringCloud微服务之Rest

    今天带大家学习SpringCloud微服务之Rest的有关知识,文中有非常详细的介绍及代码示例,对正在学习java的小伙伴们有很好的帮助,需要的朋友可以参考下
    2021-05-05
  • Spring MVC策略模式之MethodArgumentResolver源码解析

    Spring MVC策略模式之MethodArgumentResolver源码解析

    这篇文章主要为大家介绍了Spring MVC策略模式之MethodArgumentResolver源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • RabbitMQ消息拒绝如何解决

    RabbitMQ消息拒绝如何解决

    这篇文章主要介绍了RabbitMQ消息拒绝如何解决问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • JAVA内存模型(JMM)详解

    JAVA内存模型(JMM)详解

    这篇文章主要介绍了JAVA内存模型(JMM)详解的相关资料,需要的朋友可以参考下
    2022-12-12

最新评论