MyBatis概述环境搭建(一)

news/2024/9/17 9:39:39/

🚗MyBatis学习·起始站~
🚩本文已收录至专栏:数据库学习之旅
👍希望您能有所收获

一.什么是MyBatis

(1) 引言

  • MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射
  • MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。
  • MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

上述是官网对其的定义,详细可见:MyBatis中文网

**什么是持久层?框架又是啥?对比使用JDBC又有什么优势呢?**接下来让我们一个个来看看吧~

(2) 持久层

在构建复杂的应用程序时,三层架构是我们常用到的一种软件设计架构,它将一个应用程序分为三个主要的层次:表现层、业务逻辑层、数据访问(持久)层。使得应用程序可以分解为独立的、可重用的部分,从而提高开发效率和代码的可维护性以及实现不同层之间的松耦合。
在这里插入图片描述

通常情况下,持久层负责与数据存储和持久化相关的操作。它提供了一种将应用程序中的对象映射到数据存储技术(如关系型数据库)的机制,并提供了各种数据访问接口,例如CRUD(创建、读取、更新和删除)操作等,通过使用持久层,应用程序可以更方便地操作和管理数据,而不必关心具体的存储细节。

(3) 框架

  • 框架就是一个半成品软件,在框架的基础之上构建软件编写更加高效、规范、通用、可扩展。

  • 当我们写软件时,通常需要实现一些通用的功能,比如说处理HTTP请求、连接数据库、用户身份认证等等。这些通用的功能,每次写一个新软件都要重复编写,浪费时间和精力。框架就是为了解决这个问题而生的,它提供了一套通用的代码基础,包含了这些通用的功能,开发人员可以在这个基础上进行开发,不用重复写这些通用的功能,提高开发效率。

  • 通过一个框架只能完成同一项工作,例如我们使用MyBatis只能完成持久层方面开发技术。
    在这里插入图片描述

我们可以使用石膏雕像(半成品软件)快速绘画出一个漂亮的小女孩(简化开发),却不能将其绘制成一个小男孩(只能完成同一项工作)。

(4) 简化JDBC开发

  • JDBC 缺点:

    • 硬编码:连接数据库以及SQL为字符串,当发生变动再修改时过程十分繁琐且容易遗漏。
    • 操作繁琐:设置参数以及对结果集处理过程比较繁琐。
      在这里插入图片描述
  • MyBatis 简化:

    • 配置文件:通过配置文件统一管理连接以及SQL代码。
    • 自动完成:自动封装执行结果集。
      在这里插入图片描述

MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。当然MyBatis并不是唯一的持久层框架,还有许多的其他框架,但它却是国内最受欢迎的持久层框架之一。

二.MyBatis快速入门

入门_MyBatis中文网官方网站也详细介绍了如何搭建MyBatis环境,接下来让我们一起在Idea的Maven工程中通过一个简单的查询案例实践一下~

(1) 在数据库创建表

首先我们要在数据库中创建一张用于入门案例的数据表。

create database mybatis;
use mybatis;drop table if exists tb_user;create table tb_user(id int primary key auto_increment,username varchar(20),password varchar(20),gender char(1),addr varchar(30)
);INSERT INTO tb_user VALUES (1, 'zhangsan', '123', '男', '北京');
INSERT INTO tb_user VALUES (2, '李四', '234', '女', '天津');
INSERT INTO tb_user VALUES (3, '王五', '11', '男', '西安');

(2) 创建Maven工程

为了避免手动导入jar包的麻烦,我们可以创建一个Maven工程
在这里插入图片描述

(3) 导入依赖

  1. 按官方文档所述,我们要想在Maven工程中使用MyBatis必须在pom文件中导入如下坐标:
<dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>x.x.x</version>
</dependency>

注意:x.x.x需要改为自己想使用的版本,例如3.5.5

  1. 此外,因为我们要连接MySQL数据库,因此还要导入MySQL连接驱动。
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.28</version>
</dependency>

注意:8.0.28可根据需要改为自己想使用的版本

  1. 有上述这些就已经能使用了,但如果你想查看运行日志信息,则还需要导入如下坐标
<!-- 添加slf4j日志api -->
<dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>1.7.20</version>
</dependency>
<!-- 添加logback-classic依赖 -->
<dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version>
</dependency>
<!-- 添加logback-core依赖 -->
<dependency><groupId>ch.qos.logback</groupId><artifactId>logback-core</artifactId><version>1.2.3</version>
</dependency>	

要使用日志功能,除了导入上述三个坐标以外,还需要在Resource目录下创建包含以下内容的logback.xml配置文件:
在这里插入图片描述

<?xml version="1.0" encoding="UTF-8"?>
<configuration><!--CONSOLE :表示当前的日志信息是可以输出到控制台的。--><appender name="Console" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>[%level] %blue(%d{HH:mm:ss.SSS}) %cyan([%thread]) %boldGreen(%logger{15}) - %msg %n</pattern></encoder></appender><logger name="com.itheima" level="DEBUG" additivity="false"><appender-ref ref="Console"/></logger><!--level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF, 默认debug<root>可以包含零个或多个<appender-ref>元素,标识这个输出位置将会被本日志级别控制。--><root level="DEBUG"><appender-ref ref="Console"/></root>
</configuration>

(4) 编写核心配置文件

MyBatis 核心配置文件的作用之一便是解决我们上述提到的硬编码问题中的连接信息。

根据官方文档从 XML 中构建 SqlSessionFactory所给的方案,我们需要在Resource目录下创建包含以下内容的mybatis-config.xml配置文件:
在这里插入图片描述

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><!--数据库连接信息--><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost/mybatis?useSSL=false"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><mappers><!--加载SQL映射文件--><mapper resource="org/mybatis/example/BlogMapper.xml"/></mappers>
</configuration>

(5) 编写 SQL 映射文件

SQL 映射文件的作用便是帮助我们统一管理sql语句,在代码中解决硬编码问题。

根据官方文档从所述,我们同样需要在Resource目录下创建包含以下内容的UserMapper.xml配置文件,为了规范命名一般为表名+Mapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="test"><select id="selectAll" resultType="guanzhi.pojo.User">select * from tb_user</select><insert id="xx">插入语句</insert><delete id="xx">删除语句</delete><update id="xx">更新语句</update>
</mapper>
  • 我们需要先写一个名为mapper的根标签,然后再进行一系列CRUD操作
  • namespace:名称空间,区分不同mapper的的代码
  • id: SQL语句的唯一标识,不能重复
  • resultType: 返回结果类型,例如:guanzhi.pojo.User,我们需要创建一个User类
    在这里插入图片描述
public class User {// 表字段private Integer id;private String username;private String password;private String gender;private String addr;// 为节省篇幅,需自己写一下get与set方法
}

如上即可简单完成SQL 映射文件 配置,至此我们还需要将上述MyBatis核心配置文件中的mappers改为UserMapper.xml的类路径,

    <mappers><!--加载SQL映射文件--><!--因为我们的UserMapper.xml和mybatis-config.xml在相同目录下因此只需如下配置--><mapper resource="UserMapper.xml"/></mappers>

至此我们已经完成了MyBatis的基本配置,接下来让我们一起来使用一下吧。

(6) 使用

根据官方文档所述,我们要使用基于 MyBatis 的应用,必须先加载核心配置文件,获取 SqlSessionFactory 对象,然后再进行一系列操作

public class MyBatisDemo {public static void main(String[] args) {try {// 1. 加载mybatis的核心配置文件,获取SqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 2. 获取SqlSession对象,用于执行sqlSqlSession sqlSession = sqlSessionFactory.openSession();// 3. 执行UserMapper中的sql语句,namespace.idList<User> userList = sqlSession.selectList("test.selectAll");System.out.println(userList);// 4.释放资源sqlSession.close();} catch (IOException e) {e.printStackTrace();}}
}

执行程序可以看到我们已经成功查询到了在数据库中的几条数据。
在这里插入图片描述

至此我们已经成功在idea中使用了MyBatis,可能许多同学会觉得过程太繁琐了,还不如不用,但是我们仔细查看可以发现,上述的很多配置几乎只需要进行一次配置即可,后续便无需进行。

三.Eclipse中搭建(补充)

在Eclipse同样可以使用MyBatis,操作步骤几乎与上述一致,只是相对没有idea那么好用而已。

  1. 例如我们创建一个动态web工程
    在这里插入图片描述

  2. 接下来就是一些几乎一致的操作,就不再赘述。


http://www.ppmy.cn/news/26797.html

相关文章

02-04 周六 图解机器学习 SVM 支持向量机分类学习

02-04 周六 图解机器学习 SVM 支持向量机分类学习时间版本修改人描述2023年2月4日11:15:16V0.1宋全恒新建文档 环境搭建 首先搭建jupyter环境&#xff0c;方便可视化 (base) rootnode33-a100:~# docker run --name sqh-learn -d -p 10088:8888 -it 10.101.12.128/framework/ju…

生态应用:探讨 NGINX 与上下游系统集成时的开发经验

NGINX 作为一款高性能的 Web 服务器和反向代理服务器&#xff0c;在各种应用场景中广泛应用。随着业务的发展&#xff0c;我们在使用 NGINX 时&#xff0c;可能需要将其与其他系统进行集成&#xff0c;以实现更加复杂的业务需求。 本文将结合实际应用场景&#xff0c;探讨 NGI…

带你一步步搭建Web自动化测试框架

测试框架的设计有两种思路&#xff0c;一种是自底向上&#xff0c;从脚本逐步演变完善成框架&#xff0c;这种适合新手了解框架的演变过程。另一种则是自顶向下&#xff0c;直接设计框架结构和选取各种问题的解决方案&#xff0c;这种适合有较多框架事件经验的人。本章和下一张…

Linux之网络流量监控工具ntopng YUM安装

一、ntopng简介 Ntop是一种监控网络流量工具&#xff0c;用ntop显示网络的使用情况比其他一些网络管理软件更加直观、详细。Ntop甚至可以列出每个节点计算机的网络带宽利用率。他是一个灵活的、功能齐全的&#xff0c;用来监控和解决局域网问题的工具&#xff1b;尤其当ntop与n…

非标题党:前端Vue React 项目编程规范化配置(大厂规范)

前端项目编程规范化配置 下述例子主要是从 代码规范化 以及 git 提交规范化 两方面进行配置。内容很多&#xff0c;请做好心理准备 一、代码检测工具 ESLint 在我们通过 vue create “项目名” 时&#xff0c;我们可以通过手动配置的方式&#xff0c;来配置 ESLint 来对代码进…

python 绘图 —— 绘制从顶部向底部显示的柱形图[ax.bar()]

python 绘图 —— 绘制从顶部向底部显示的柱形图[ax.bar()] 效果图如下所示&#xff1a; 就是这个样子&#xff0c;一般比较少见将柱形图从上往下绘制的。可能是会为了更好的展示数据对比结果吧。这里绘图的主要思路如下&#xff1a; 利用ax.twinx()这个函数生成一个新的x轴…

双因素方差分析全流程

上篇文章讲述了“单因素方差分析全流程总结”&#xff0c;单因素方差分析只是考虑了一个自变量&#xff08;定类&#xff09;与一个因变量&#xff08;定量&#xff09;之间的关系&#xff0c;但是在实际问题研究中可能研究两个或者几个因素与因变量之间的关系&#xff0c;例如…

鼠标指针文件格式解析

鼠标指针文件格式解析 文章目录鼠标指针文件格式解析windowsico文件格式分析文件头&#xff1a;图像数据头段&#xff1a;图像数据段&#xff1a;Ani动态光标格式解析数据结构&#xff1a;anihseq **rate**LISTcur静态光标文件格式解析macOSLinuxwindows ico文件格式分析 是一…

1-MATLAB APP Design-图像的输入与输出

一、APP 界面设计展示 新建一个空白的APP,在此次的学习中,我们会用到编辑字段(文本框)、 按钮、坐标区和面板,首先在界面中拖入一个编辑字段(文本框),在文本框中输入内容:图形的输入与输出,调整背景颜色,字体的颜色为黑色,字体的大小调为25.

UG NX二次开发(C#)-CAM-不再高亮显示所有的加工特征(CAMFeature)

文章目录 1、前言2、加工特征高亮显示的示例3、获取加工特征的几何对象3.1 获取面对象并取消高亮显示3.2 获取坐标系对象并取消高亮显示4、创建一个不再高亮显示所有加工特征的方法1、前言 当我们在识别加工特征后,其默认状态是被选中的,所以是高亮显示;当我们不再选中时,…

06- OpenCV查找图像轮廓 (OpenCV基础) (机器视觉)

知识重点 灰度图转换: gray cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)二值化: 返回两个东西&#xff0c;一个阈值&#xff0c; 一个是二值化的图: thresh, binary cv2.threshold(gray, 150, 255, cv2.THRESH_BINARY)查找轮廓: 返回两个结果&#xff0c;分别是轮廓和层级: c…

【C语言】浮点型数据在内存中的存储

&#x1f680;&#x1f680;&#x1f680; 如果文章对你有帮助不要忘记点赞关注收藏哦&#x1f680;&#x1f680;&#x1f680; 文章目录⭐浮点数在内存中的存储1.1 &#x1f913;举个例子:1.2浮点数存储规则&#x1f308;&#xff1a;对于M与E有一些特别规定1.3解释前面题目&…

STM32开发(11)----CubeMX配置独立看门狗(IWDG)

CubeMX配置独立看门狗&#xff08;IWDG&#xff09;前言一、独立看门狗的介绍二、实验过程1.STM32CubeMX配置独立看门狗2.代码实现3.硬件连接4.实验结果总结前言 本章介绍使用STM32CubeMX对独立看门狗定时器进行配置的方法。门狗本质上是一个定时器&#xff0c;提供了更高的安…

嵌入式Qt 开发一个视频播放器

上篇文章&#xff1a;嵌入式 Qt开发一个音乐播放器&#xff0c;使用Qt制作了一个音乐播放器&#xff0c;并在OK3568开发板上进行了运行测试&#xff0c;实际测试效果还不错。 本篇继续来实现一个Qt视频播放器软件&#xff0c;可以实现视频列表的显示与选择播放等&#xff0c;先…

centos7下用kvm启动Fedora36 Cloud镜像

环境 os:centos7 Arch: aarch64 安装qemu-kvm yum install qemu-kvm kvm virt-install libvirt systemctl start libvirtd.service创建镜像 下载aarch64架构的Fedora36镜像 wget https://mirrors.tuna.tsinghua.edu.cn/fedora/releases/36/Cloud/aarch64/images/Fedora-Cl…

PaddleSlim 模型量化 源代码解读

前言&#xff1a;paddleslim的中文资料非常丰富&#xff0c;在如何使用的教学上做的非常完善。但是源码解读与解析资料却非常少&#xff0c;这篇博客结合源代码大家一起学习一下paddle静态离线量化的原理和方法。 目录 原理简述 支持的量化类型 支持后端 量化操作 Prepara…

基于linux内核的驱动开发

1 自动创建设备文件 创建设备文件的方式&#xff1a;1 手动创建 sudo mknod /dev/haha0 c 250 0 2 自动创建--》使用内核函数 linux内核为我们提供了一组内核函数&#xff0c;用于在模块加载时自动在/dev目录下创建响应的设备文件&…

vue-element-admin在git 上 clone 之后无法install

一. 无法install的原因因为vue-element-admin引入的富文本编辑插件所导致 由于tui-editor变更 名字 导致 依赖查询找不到对应的版本二. 解决的办法先删掉package.json中tui-editor:1.3.3找到 \src\components\MarkdownEditor\index.vue 把所有的import 替换成下面4个import cod…

【Kubernetes】【十九】安全认证

第九章 安全认证 本章节主要介绍Kubernetes的安全认证机制。 访问控制概述 ​ Kubernetes作为一个分布式集群的管理工具&#xff0c;保证集群的安全性是其一个重要的任务。所谓的安全性其实就是保证对Kubernetes的各种客户端进行认证和鉴权操作。 客户端 在Kubernetes集群…

23春招-mysql事务相关高频面试题

1、什么是事务 对于一个事务&#xff0c;要么事务内的sql全部执行&#xff0c;要么都不执行 2、 事务的特性ACID 原子性 整个事务中所有的操作要么全部提交成功&#xff0c;要么全部失败会滚。 一致性 数据库总是从一个一致性状态转换到另一个一致性状态。假如有三个sql语句…