Mybatis背景简介及其优缺点

news2025/1/23 7:09:21

文章目录

    • 1. JDBC简介
      • 1.1 jdbc架构图
      • 1.2 jdbc例子
      • 1.3 jdbc缺点
    • 2. Mybatis
      • 2.1 iBATIS是什么
      • 2.2 Mybatis是什么
      • 2.3 和其他持久层框架的本质区别
      • 2.4 Mybatis和Hibernate的共同点
      • 2.5 Mybatis的优缺点
        • 2.5.1 Mybatis的优点
        • 2.5.2 Mybatis的缺点
      • 2.6 Hibernate的优缺点
        • 2.6.1 Hibernate的优点
        • 2.6.2 Hibernate的缺点
      • 2.7 Mybatis和Hibernate的应用场景
      • 2.8 总结
    • 3. 参考

1. JDBC简介

JDBC全称Java Database Connectivity,是Java语言规范客户端访问数据库的应用程序接口,所面向的数据库类型为关系型数据库

1.1 jdbc架构图

jdbc架构图
JDBC 的 API 提供了以下接口和类:

  • DriverManager :这个类管理一系列数据库驱动程序。匹配连接使用通信子协议从 JAVA 应用程序中请求合适的数据库驱动程序。识别 JDBC 下某个子协议的第一驱动程序将被用于建立数据库连接。

  • Driver : 这个接口处理与数据库服务器的通信。你将很少直接与驱动程序互动。相反,你使用 DriverManager 中的对象,它管理此类型的对象。它也抽象与驱动程序对象工作相关的详细信息。

  • Connection : 此接口具有接触数据库的所有方法。该连接对象表示通信上下文,即所有与数据库的通信仅通过这个连接对象进行。

  • Statement : 使用创建于这个接口的对象将 SQL 语句提交到数据库。除了执行存储过程以外,一些派生的接口也接受参数。

  • ResultSet : 在你使用语句对象执行 SQL 查询后,这些对象保存从数据库获得的数据。它作为一个迭代器,让您可以通过它的数据来移动。

  • SQLException : 这个类处理发生在数据库应用程序的任何错误。

1.2 jdbc例子

public class JdbcTest {
    public static void main(String[] args) {
        //数据库连接
        Connection connection = null;
        //预编译的Statement,使用预编译的statement的可以提高性能,使用statement操作数据库
        PreparedStatement preparedStatement = null;
        //结果集
        ResultSet resultSet = null;

        try {
            //加载数据库驱动
            Class.forName("com.mysql.jdbc.Driver");
            //通过数据驱动管理类获取数据库链接
            connection =DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatisdata?characterEncoding=utf-8","root","root");
            //定义sql语句,其中?标识占位符
            String sql = "select * from user where id = ?";
            //获取预处理statement
            preparedStatement = connection.prepareStatement(sql);
            //设置参数,第一个参数为sql中参数的序号,第二个参数为设置的参数值
            preparedStatement.setInt(1,1);
            //向数据库发出sql查询,查询出数据集
            resultSet = preparedStatement.executeQuery();
            //遍历查询结果
            while(resultSet.next()){
                System.out.println(resultSet.getString("id")+"->"+resultSet.getString("username")+"->"+resultSet.getString("sex"));
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            //释放资源
            if(resultSet != null){
                try {
                    resultSet.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if(preparedStatement!=null){
                try {
                    preparedStatement.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if(connection != null){
                try {
                    connection.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

1.3 jdbc缺点

从代码中可以看到jdbc很多缺点,比如:

  1. 每次访问数据库都需要创建数据库连接,最后不需要使用还得释放连接,频繁地连接释放连接会造成系统资源浪费,从而影响系统性能
  2. 需要在Java代码里面编写SQL语句,SQL语句发生改动,需要重新编译Java代码,就种硬编码的方式造成代码不易维护的缺点;
  3. Preparedstatement中设置的参数要与占位符在数量上一一对应,而且查询的条件不确定,参数或多或少,这就能引起很多麻烦;
  4. ResultSet中遍历结果时,需要对应相应数据库字段,这些字段属于硬编码,也不利于系统的维护。

2. Mybatis

2.1 iBATIS是什么

提到Mybatis,就不能不想到iBATIS,那么iBATIS到底和Mybatis有什么关系呢?

Mybatis的前身是iBATIS,是Clinton Begin在2001年发起的一个开源项目,最初侧重于密码软件的开发,后来发展为一款基于Java的持久层框架。2004年Clinton 将iBATIS捐给Apache软件基金会,2010年iBATIS改名Mybatis,所以iBATIS和Mybatis是同一个东西不同阶段。

2.2 Mybatis是什么

Mybatis是一款优秀的支持自定义SQL查询、存储过程和高级映射的持久层框架,消除了几乎所有的JDBC代码和参数的手动设置以及结果集的检索

Mybatis可以使用XML或者注解进行配置和映射,通过将参数映射到配置中的SQL,形成最终执行的SQL语句,最终将执行SQL语句的结果映射到Java对象返回

2.3 和其他持久层框架的本质区别

与其他映射框架本质区别:

Mybatis 不是把 Java对象 直接和数据库联系起来,而是把 Java对象SQL语句 联系起来,把对象传进SQL语句来设置参数。

而其他映射框架,比如 Hibernate 是直接将 Java对象数据库表字段 联系起来。

2.4 Mybatis和Hibernate的共同点

  • 从配置文件(通常是 XML 配置文件中)得到 sessionfactory.
  • 由 sessionfactory 产生 session
  • 在 session 中完成对数据的增删改查和事务提交等.
  • 在用完之后关闭 session 。
  • 在 Java 对象和 数据库之间有做 mapping 的配置文件,也通常是 xml 文件。

2.5 Mybatis的优缺点

2.5.1 Mybatis的优点

  • 易于上手和掌握。
  • sql写在xml里,便于统一管理和优化。
  • 解除sql与程序代码的耦合。
  • 提供映射标签,支持对象与数据库的orm字段关系映射
  • 提供对象关系映射标签,支持对象关系组建维护
  • 提供xml标签,支持编写动态sql。

2.5.2 Mybatis的缺点

  • sql工作量很大,尤其是字段多、关联表多时,更是如此。
  • sql依赖于数据库,导致数据库移植性差。
  • 由于xml里标签id必须唯一,导致DAO中方法不支持方法重载。
  • 字段映射标签和对象关系映射标签仅仅是对映射关系的描述,具体实现仍然依赖于sql。
  • DAO层过于简单,对象组装的工作量较大。
  • 不支持级联更新、级联删除。
  • 编写动态sql时,不方便调试,尤其逻辑复杂时。
  • 提供的写动态sql的xml标签功能简单,编写动态sql仍然受限,且可读性低。
  • 若不查询主键字段,容易造成查询出的对象有“覆盖”现象。
  • 参数的数据类型支持不完善。
  • 多参数时,使用不方便,功能不够强大。
  • 缓存使用不当,容易产生脏数据。

2.6 Hibernate的优缺点

2.6.1 Hibernate的优点

  • Hibernate 使用 XML 文件来处理映射 Java 类别到数据库表格中,并且不用编写任何代码。
  • 为在数据库中直接储存和检索Java 对象提供简单的 APIs。
  • 如果在数据库中或任何其它表格中出现变化,那么仅需要改变 XML 文件属性。
  • 抽象不熟悉的 SQL类型,并为我们提供工作中所熟悉的 Java 对象。
  • Hibernate 不需要应用程序服务器来操作。
  • 操控你数据库中对象复杂的关联。
  • 最小化与访问数据库的智能提取策略。
  • 提供简单的数据询问。

2.6.2 Hibernate的缺点

  • 全表映射带来的不便,比如更新时需要发送所有的字段
  • 无法根据不同的条件组装不同的SQL
  • 对多表关联和复杂的sql查询支持较差,需要自己写sql,返回后,需要自己将数据封装为pojo。
  • 不能有效的支持存储过程
  • 虽然有HQL,但是性能较差,大型互联网系统往往需要优化sql,而hibernate做不到。

2.7 Mybatis和Hibernate的应用场景

  • Mybatis适用于需求多变的互联网项目,例如电商项目。
  • Hibernate适用于需求明确、业务固定的项目,例如OA项目、ERP项目等。

2.8 总结

Hibernate是一个标准的ORM映射框架,程序员无需配置SQL语句,只需要配置好Java对象与数据库的映射文件.hbm.xml,但是对SQL的优化和修改是比较困难的

Mybatis是一个不完整的ORM映射框架,需要程序员编写SQL语句,这很考验程序员的能力,对SQL语句的优化和修改是比较方便的。面对需求量变化比较多的项目来说,选用Myabtis是比较适合的。

3. 参考

https://www.cnblogs.com/magic-sea/p/11189849.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/686588.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

工作流引擎技术选型

一、主流开源框架介绍 1、工作流相关文档 1.Camunda 官方文档:https://camunda.com/ 中文文档:介绍 | docs.camunda.org 2.Activiti 官方文档:https://www.activiti.org/ 中文文档:[activiti6用户手册 3.Snaker 官方文档&…

【PCIE体系结构十四】电气物理层之发送端FFE

👉个人主页:highman110 👉作者简介:一名硬件工程师,持续学习,不断记录,保持思考,输出干货内容 参考书籍:《PCI.EXPRESS系统体系结构标准教材 Mindshare》 参考文章&…

Docker 安装 Nginx,并实现负载均衡

1、获取 nginx 的镜像 # 默认是latest版本docker pull nginx 2、运行 nginx 容器 docker run --name nginx-80 -p 80:80 --rm -d nginx# --name nginx-80 设定容器的名称# -p 80:80 端口进行映射,将本地的80端口映射到容器内部的80端口# --rm 表示容器退出后直接…

云安全技术——Hyper-V虚拟化技术

目录 5-1 了解Hyper-V 5-2 安装Hyper-V 5-3创建虚拟机 Hyper-V虚拟化技术 实验目的 了解 Windows 虚拟化的概念 了解 Hyper-V的背景及发展 了解 Hyper-V 的功能特性 了解 Hyper-V的体系架构 实验要求 能描述 Hyper-V 的功能特性 能在 Windows 2012 R2系统下部署 Hyper-V 能使…

SpringBoot整合MyBatis分页

SpringBoot整合MyBatis分页 一、pagehelper分页1、添加相关依赖2、添加相关配置3、添加分页配置4、添加代码5、测试 二、拦截器分页1、添加相关配置2、添加拦截器代码和配置3、添加代码4、测试4、测试 本文目标: SpringBoot整合Mybatis分页的两种方式,一…

Python基础八

目录 一、Python条件控制语句 1.执行过程 2.if 语句 if中常用的操作运算符: if 嵌套 3.match...case语句 二、Python循环控制语句 1.while循环 while无限循环 while 循环使用 else 语句 2.for 循环语句 for...in...循环 for循环使用else语句 for...in range()…

2023年3季度DAMA-CDGA/CDGP数据治理认证即将开班

DAMA认证为数据管理专业人士提供职业目标晋升规划,彰显了职业发展里程碑及发展阶梯定义,帮助数据管理从业人士获得企业数字化转型战略下的必备职业能力,促进开展工作实践应用及实际问题解决,形成企业所需的新数字经济下的核心职业…

你知道ai绘画生成器怎么弄吗

在数字时代,艺术也开始走向了自动化。随着人工智能技术的进步,ai绘画软件已经开始逐渐普及。它们可以利用先进的神经网络算法,学习人类艺术家的风格和技巧,从而生成出高度逼真的艺术作品。这些作品虽然没有人类艺术家的创意和灵魂…

Linux系统编程(终端和进程的关系)

文章目录 前言一、终端和控制台二、TTY和PTY三、终端的类型四、Gnome Terminal伪终端总结 前言 本篇文章带大家学习终端和进程的关系,终端相信大家都听过,那么真的理解终端是什么吗?应该有很多同学对于终端只是有一个模糊的概念。那么这篇文…

【算法题】合并两个有序链表、删除字符串 s1 中在字符串 s2 中出现的字符、求一个论坛一天的在线人数分布

合并两个有序链表、删除字符串 s1 中在字符串 s2 中出现的字符、求一个论坛一天的在线人数分布 一、合并两个有序链表1.1、题目描述1.2、思路1.3、代码实现1.4、小结 二、删除字符串 s1 中在字符串 s2 中出现的字符2.1、题目描述2.2、思路2.3、代码实现2.4、小结 三、求一个论坛…

项目进度类知识要点

单代号网络图 六标时法正推法逆推法 六标时法最早开始时间(ES)工期最早完成时间(EF)活动名称/活动编号最迟开始时间(LS)浮动时间(总时差)最迟完成时间(LF) 关键路径、计算项目的总工期 关键路径是最大长度关键路径上的活动是关键活动关键活动之和为总工期 关键路径变化问题…

华为18级工程师三年心血终成趣谈网络协议文档(附大牛讲解)

前言 虽然在大学的时候大家都学过网络协议 ,但是肯定感觉网络协议的知识点非常多 ,非常复杂。学的时候就浑浑噩噩,真正到了实践中更是糊里糊涂,一旦工作中遇到了网络问题,除了会简单地 ping 几下 ,基本没有…

安装Jmeter

Jmeter是Java语言开发,所以需要java环境,所以先安装jdk 1.安装JDK(1.8版本以上) 下载: https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html 找到对应的版本: 点击exe文件安装,跟着向导下一步 2.安装jmeter 下载 Jmeter : 版…

【Java】JVM(六)

垃圾回收 分代回收理论 当前商业虚拟机的垃圾回收器,大多遵循“分代收集”的理论来进行设计,这个理论大体上是这么描述的: 1、绝大部分的对象都是朝生夕死。 2、熬过多次垃圾回收的对象就越难回收。 根据以上两个理论,朝生夕…

【Java】JVM学习(四)

对象的分配 JVM中对象的创建过程 对象的内存分配 虚拟机遇到一条new指令时,首先检查是否被类加载器加载,如果没有,那必须先执行相应的类加载过程。 类加载就是把class加载到JVM的运行时数据区的过程。 1)检查加载 首先检查这…

从选题、创作、编辑、推广到优化,23个必用的内容营销工具

咱们做内容营销的,要懂营销懂产品,看得懂技术语言,写得了行业洞察,做出来的内容要有创意还要接地气,专业内容也不能落下,除了会写,还要会运营会设计会剪视频,简直就是全才嘛。 但是…

你知道游戏配音怎么制作吗?教你游戏配音教程怎么做

曾经,有一个叫小明的游戏迷,他对于游戏世界充满了热爱和想象。每当他控制着自己喜爱的角色在游戏中冒险时,他总是希望能够为这些角色赋予独特的声音,让它们真正活起来。然而,他却面临一个问题:游戏配音教程…

【CTF-Reverse中的加密算法】密码算法特征识别,变种密码算法分析

上一章中我们带领大家了解了加密算法——RC4,TEA,Base64算法的原理,但是加密算法远不止这些,需要大家自行去学习,在这一章中,我来带领大家了解密码算法特征识别,变种密码算法分析。 一.密码算法特征识别 1.什么是特征…

详解MySQL的常用数据类型

文章目录 一、MySQL 数据类型1.1、mysql中编码和字符 二、数值类型2.1、整数类型的长度2.2、浮点型 三、字符串类型3.1、字符串类型长度 四、日期和时间类型4.1、DATETIME 五、二进制数据类型六、使用建议 一、MySQL 数据类型 MySQL支持很多数据类型,以便我们能在复…

实现定时任务

1 问题 定时任务中,每天统计一下今日博客的各项数据,并以邮件的形式发送给自己。 2 方法 .首先在某目录下新建任务文件 crontest.cron,用于存在定时任务语句。.相同目录新建 hello.py 文件,并且编辑这个文件写一句简单的 print(He…