1.什么是MyBatis?
MyBatis是一款优秀的持久层框架,它支持自定义SQL、存储过程以及高级映射。MyBatis去除了几乎所有的JDBC代码以及设置参数和获取结果集的工作。MyBatis可以通过简单的XML或注解来配置和映射原始类型、接口和Java POJO(Plain Old Java Objects,普通老式Java对象)为数据库中的记录。
简单来说,MyBatis是更简单完成程序和数据库交互的工具,也就是更简单的操作和读取数据库的工具。
MyBatis也是一个ORM框架,ORM(Object Relational Mapping),即对象关系映射。在面向对象编程语言中,将关系型数据库中的数据与对象建立起映射关系,进而自动的完成数据与对象的互相转换:
1.将输入数据(即传入对象)+ SQL映射成原生SQL
2.将结果集映射为返回对象,即输出对象
ORM把数据库映射为对象:
数据库表(table) --> 类(class)
记录(record,行数据) -->对象(object)
字段(filed) --> 对象的属性(attribute)
一般的ORM框架,会将数据库模型的每张表都映射为一个Java类。
也就是说使用MyBatis可以像操作对象一样来操作数据库中的表,可以实现对象和数据库表之间的转换,接下来我们来看MyBatis具体该如何使用吧。
2.第一个MyBatis查询
2.1 创建MyBatis项目
2.1.1 创建项目添加相关依赖
此步骤分为两种情况,一种是需要创建新项目,这时直接进行勾选相关依赖即可,而如果是旧项目,直接在pom.xml文件中使用插件添加MyBatis相关依赖即可。
新项目:
老项目:
完成相关依赖的添加后,先不要急着启动项目,需要完成下一步配置才能够连接上数据库。
2.1.2 配置数据库连接字符串和MyBatis(保存的XML目录)
配置数据库连接信息
在开发环境和生产环境都需要进行数据库连接信息的配置。
配置MyBatis的XML保存路径
在主配置文件中配置运行的环境和MyBatis的XML保存路径
2.1.3 创建数据库和数据表(用于测试)
-- 创建数据库 drop database if exists mycnblog; create database mycnblog DEFAULT CHARACTER SET utf8mb4; -- 使用数据数据 use mycnblog; -- 创建表[用户表] drop table if exists userinfo; create table userinfo( id int primary key auto_increment, username varchar(100) not null, password varchar(32) not null, photo varchar(500) default 'default.png', createtime datetime default now(), updatetime datetime default now(), `state` int default 1 ) default charset 'utf8mb4'; -- 创建文章表 drop table if exists articleinfo; create table articleinfo( id int primary key auto_increment, title varchar(100) not null, content text not null, createtime datetime default now(), updatetime datetime default now(), uid int not null, rcount int not null default 1, `state` int default 1 )default charset 'utf8mb4'; -- 创建视频表 drop table if exists videoinfo; create table videoinfo( vid int primary key, `title` varchar(250), `url` varchar(1000), createtime datetime default now(), updatetime datetime default now(), uid int )default charset 'utf8mb4'; -- 添加一个用户信息 INSERT INTO `mycnblog`.`userinfo` (`id`, `username`, `password`, `photo`, `createtime`, `updatetime`, `state`) VALUES (1, 'admin', 'admin', '', '2021-12-06 17:10:48', '2021-12-06 17:10:48', 1); -- 文章添加测试数据 insert into articleinfo(title,content,uid) values('Java','Java正文',1); -- 添加视频 insert into videoinfo(vid,title,url,uid) values(1,'java title','http://www.baidu.com',1);
将代码在MySQL客户端进行复制运行。
2.2 使用MyBatis的操作模式操作数据库
下图按照后端开发的工程思路,也就是下面的流程来实现MyBatis操作数据库。
在我的文章【Spring更简单的存储和读取Bean】1.3中有下边这样一幅图,展示了程序各个工程的分层,所以我们实现业务代码就是需要按照这样的分层来实现。
先在项目的启动类的同一级目录中创建包,做好项目的分层工作。
2.2.1 添加实体类
在model包下先添加用户的实体类
2.2.2 添加mapper接口
数据持久层的接口定义:
2.2.3 添加UserMapper.xml
数据持久层的实现,MyBatis的固定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"> <!-- namespace 要设置是实现接口的具体包名加接口名 --> <mapper namespace="com.example.demo.mapper.UserMapper"> </mapper>
2.2.4 添加Service
在service包下实现服务层代码:
2.2.5 添加Controller
在controller包下实现控制器层:
2.2.6 测试
在浏览器中输入URL进行测试:
3.总结:MyBatis执行流程图