环境:
- JDK 1.8
- MySQL 8.0.28
- maven 3.8.5
- IDEA
基础:
- JDBC
- MySQL
- Java
- Maven
- Junit
框架:配置文件 官网文档
1. 简介 1.1 什么是MyBatis- 持久层框架
- 定制化SQL、存储过程、高级映射
- 避免JDBC、手动设置参数、获取结果集
- XML、注解配置映射原生类型、接口、POJO为数据库中的记录
- apache的开源项目iBatis(internet + abatis)基于Java 2010年由apache software foundation迁移到了google code 改名为MyBatis
- 2013.11 迁移到github
- iBatis提供的持久层框架包括SQL Maps 和 Data Access Objects(DAOs)
获取:
-
maven:
org.mybatis mybatis 3.5.9 -
Github:https://github.com/mybatis/mybatis-3/releases
-
中文文档:https://mybatis.org/mybatis-3/zh/getting-started.html
- 数据持久化:将程序中的数据在持久状态和瞬时状态转化的过程
- 内存:断电即失
- 数据库(JDBC)、IO文件持久化
持久化的意义:
- 有些对象不能丢失
- 内存价格高
Dao Service Controller
- 完成持久化工作的代码块
- 层 界限明显
- 将数据存入数据库中
- 方便、灵活
- 简化JDBC 框架
- 可替代,但更容易上手
- sql与代码分离
- 提供映射标签、支持对象和数据库的orm字段关系映射
- 提供对象关系映射标签,支持对象关系组建维护
- 提供xml标签,可编写动态SQL
-
搭建数据库
CREATE DATABASE `mybatis`; USE mybatis CREATE TABLE `user`( `id` INT(20) NOT NULL, `name` VARCHAr(30) DEFAULT NULL, `pwd` VARCHAr(30) DEFAULT NULL, PRIMARY KEY(`id`)`mybatis``user` )ENGINE=INNODB DEFAULT CHARSET=utf8; INSERT INTO `user`(`id`,`name`,`pwd`)VALUES (1,'李倪','111111'), (2,'王记','313131'), (3,'赵新','121212'); -
新建普通maven项目
-
删除src目录
-
导入maven依赖
4.0.0 com.yl MyBatis-Study 1.0-SNAPSHOT mysql mysql-connector-java 8.0.27 org.mybatis mybatis 3.5.9 junit junit 4.12 test
-
mybatis核心配置文件
-
mybatis工具类
import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.IOException; import java.io.InputStream; //sqlSessionFactory --> sqlSession public class MyBatisUntils { private static SqlSessionFactory sqlSessionFactory; //加载资源 static{ try { //获取sqlSessionFactory对象 String resource = "org/mybatis/example/mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); } catch (IOException e) { e.printStackTrace(); } } //创建执行SQL的对象 public static SqlSession getSqlSession(){ return sqlSessionFactory.openSession(); } }
-
实体类
package com.yl.pojo; //实体类 public class User { private int id; private String name; private String pwd; public User() { } public User(int id, String name, String pwd) { this.id = id; this.name = name; this.pwd = pwd; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPwd() { return pwd; } public void setPwd(String pwd) { this.pwd = pwd; } @Override public String toString() { return "User{" + "id=" + id + ", name='" + name + ''' + ", pwd='" + pwd + ''' + '}'; } } -
DaoMapper接口
import com.yl.pojo.User; import java.util.List; public interface UserMapper { ListgetUserList(); } -
接口实现类由原来的UserDaoImpl转换为Mapper配置文件
-
junit测试
-
@Test public void test(){ //获取SqlSession对象 SqlSession sqlSession = MyBatisUntils.getSqlSession(); //执行SQL getMapper UserMapper mapper = sqlSession.getMapper(UserMapper.class); ListuserList = mapper.getUserList(); for (User user : userList) { System.out.println(user); } //关闭sqlSession sqlSession.close(); } -
报错 org.apache.ibatis.binding.BindingException: Type interface com.yl.dao.UserMapper is not known to the MapperRegistry.
-
在mybatis-config.xml下配置
-
依然报错 java.lang.ExceptionInInitializerError
-
maven 约定大于配置 在pom.xml下配置
src/main/resources ***.xml true src/main/java ***.xml false -
若依然报错 将xml的编码格式改为GBK
常见问题:
- 配置文件未注册
- 绑定接口错误
- 方法名错误
- 返回类型错误
- Maven导出资源问题
-



