【MyBatis】概述&环境搭建(一)
【摘要】 一.什么是MyBatis (1) 引言MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。上述...
一.什么是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) 导入依赖
- 按官方文档所述,我们要想在Maven工程中使用MyBatis必须在pom文件中导入如下坐标:
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>x.x.x</version>
</dependency>
注意:x.x.x
需要改为自己想使用的版本,例如3.5.5
- 此外,因为我们要连接MySQL数据库,因此还要导入MySQL连接驱动。
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.28</version>
</dependency>
注意:8.0.28
可根据需要改为自己想使用的版本
- 有上述这些就已经能使用了,但如果你想查看运行日志信息,则还需要导入如下坐标
<!-- 添加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 configuration
PUBLIC "-//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 mapper
PUBLIC "-//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的核心配置文件,获取SqlSessionFactory
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
// 2. 获取SqlSession对象,用于执行sql
SqlSession sqlSession = sqlSessionFactory.openSession();
// 3. 执行UserMapper中的sql语句,namespace.id
List<User> userList = sqlSession.selectList("test.selectAll");
System.out.println(userList);
// 4.释放资源
sqlSession.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
执行程序可以看到我们已经成功查询到了在数据库中的几条数据。
至此我们已经成功在idea中使用了MyBatis,可能许多同学会觉得过程太繁琐了,还不如不用,但是我们仔细查看可以发现,上述的很多配置几乎只需要进行一次配置即可,后续便无需进行。
三.Eclipse中搭建(补充)
在Eclipse同样可以使用MyBatis,操作步骤几乎与上述一致,只是相对没有idea那么好用而已。
例如我们创建一个动态web工程
接下来就是一些几乎一致的操作,就不再赘述。
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)