MyBatis框架快速入门 - 基本使用
创始人
2024-05-29 09:36:47

文章目录

  • MyBatis
    • MyBatis基本介绍
    • MyBaits快速入门
    • Mapper代理开发
    • MyBatis配置文件

MyBatis

MyBatis基本介绍

什么是MyBatis?

MyBatis 是一款优秀的持久层框架,用于简化 JDBC 开发

MyBatis 本是 Apache 的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github

官网:https://mybatis.org/mybatis-3/zh/index.html

持久层:

负责将数据到保存到数据库的那一层代码

JavaEE三层架构:表现层、业务层、持久层

框架:

框架就是一个半成品软件,是一套可重用的、通用的、软件基础代码模型

在框架的基础之上构建软件编写更加高效、规范、通用、可扩展

JDBC的缺点:

1.硬编码: 把不固定的变量, 固定成了字符串

2.操作繁琐: 需要手动的设置参数, 获取封装结果集

在这里插入图片描述

MyBatis是将硬编码的注册驱动或者编写SQL语句, 放到配置文件中编写:

MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作



MyBaits快速入门

案例: 使用MyBatis查询user表中所有数据

首先mysql中准备数据库mybatis, 在mybatis中创建tb_user表,添加数据

create database mybatis;
use mybatis;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', '男', '西安');

创建Maven模块,导入坐标配置文件

junitjunit3.8.1test
org.mybatismybatis3.5.5
mysqlmysql-connector-java5.1.46

org.slf4jslf4j-api1.7.20


ch.qos.logbacklogback-classic1.2.3


ch.qos.logbacklogback-core1.2.3


因为使用到了日志, 所以需要配置日志打印文件: logback.xml


[%level] %blue(%d{HH:mm:ss.SSS}) %cyan([%thread]) %boldGreen(%logger{15}) - %msg %n

编写SQL映射文件: UserMapper.xml 用于统一管理sql语句,解决硬编码问题





配置mybatis核心配置文件: mybatis-config.xm, 配置数据库连接环境, 已经加载sql映射文件l





编码:

  1. 定义实体类User
public class User {private Integer id;private String username;private String password;private char gender;private String addr;public User() {}public User(Integer id, String username, String password, char gender, String addr) {this.id = id;this.username = username;this.password = password;this.gender = gender;this.addr = addr;}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public char getGender() {return gender;}public void setGender(char gender) {this.gender = gender;}public String getAddr() {return addr;}public void setAddr(String addr) {this.addr = addr;}@Overridepublic String toString() {return "User{" +"id=" + id +", username='" + username + '\'' +", password='" + password + '\'' +", gender=" + gender +", addr='" + addr + '\'' +'}';}
}
  1. 加载核心配置文件,获取 SqlSessionFactory 对象
  2. 获取 SqlSession 对象,执行 SQL 语句
  3. 释放资源
public static void main(String[] args) throws Exception {// 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. 执行sql语句List users = sqlSession.selectList("test.selectAll");System.out.println(users);// 4. 释放资源sqlSession.close();
}

Mapper代理开发

目的:

解决原生方式中的硬编码

简化后期执行SQL

使用Mapper代理分为下面三个步骤:

需要定义一个与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下

注意, 我们不要将配置文件直接放到同名Mapper接口中去, 我们可以在配置文件中创建一个与接口所在文件相同的目录, 在编译过后会自动在同一目录下(声明目录时, 使用/分隔)

在这里插入图片描述

在这里插入图片描述

设置SQL映射文件的namespace属性为Mapper接口全限定名





在 Mapper 接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致

public interface UserMapper {// 方法名和映射文件中sql语句的id 返回User类型的集合List selectAll();
}

细节:如果Mapper接口名称和SQL映射文件名称相同,并在同一目录下,则可以在mybatis-config.xml核心配置文件中使用包扫描的方式简化SQL映射文件的加载



MyBatis配置文件

MyBatis 核心配置文件的顶层结构如下

配置各个标签时,需要遵守前后顺序

在这里插入图片描述

类型别名(typeAliases):



配置别名后, pojo文件中的实体类类名就不在区分大小写, 并且不用带包名了;

例如在Mapper映射文件中, 声明返回值类型就可以简化




environments: 配置数据库连接环境信息。可以配置多个(environment)数据库配置环境信息,通过default属性切换不同的environment定义的数据库




相关内容

热门资讯

北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...