一、MyBatis 快速入门
1.1 MyBatis简介
1.1.1 传统JDBC开发的弊端
传统的JDBC开发如下步骤如下:
- 1)注册驱动
- 2)获取连接(Connection)
- 3)获取语句对象(Statement、PreaparedStatement)
- 4)获取结果集(ResultSet)
- 5)封装到JavaBean(非常麻烦)
- 6)释放资源
public class Demo01 {
public static void main(String[] args) throws SQLException {
// 1、加载和注册驱动(jdbc4以后不需要)
// Class.forName("com.mysql.jdbc.Driver");
// 2、使用用户名、密码、URL得到连接对象
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db04", "root", "admin");
// 3、创建语句对象
Statement statement = conn.createStatement();
// 4、执行SQL语句,返回结果集
ResultSet rs = statement.executeQuery("select * from dept inner join user on d.id=user.dept_id");
//遍历结果集
while (rs.next()) {
// 取出每一行的数据,封装到JavaBean中
}
//释放资源
rs.close();
statement.close();
conn.close();
}
}
我们之前一直使用的是JDBC来操作数据,存在如下几个问题:
- 1)步骤太过繁琐,每一次的SQL语句执行都需要重复上面几个步骤
- 2)SQL语句存在硬编码,SQL语句和Java代码耦合在一起,如果SQL语句变动需要修改源代码,重新编译、发布
- 3)结果集处理太过繁琐,需要一个一个手动设置值,在列数非常多的情况下,非常麻烦
- 4)无法建立关系映射,如一对多、多对多等关系无法建立,例如一个部门里面有很多员工,查询出来的数据无法自动映射到部门里面的员工,只能自己手动映射
- 5)实现动态SQL非常麻烦,如果SQL语句是根据前端传递的参数动态的变化,那么我们需要编写很多个if条件来实现不同的SQL语句生成;
- 6)频繁创建和释放数据库连接对象,非常容易造成系统资源的浪费,我们可以使用连接池(数据源)等技术来帮我们实现,MyBatis自带数据源;
1.1.2 MyBatis简介
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。
MyBatis是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
MyBatis是对JDBC的封装,让我们操作数据库更加的方便、快捷,而不需把时间和精力浪费在如何封装结果集、如何注册驱动、如何获取连接上面;
总而言之,MyBaits就是用于简化我们DAO层的开发、在此之外还提供其他一些高级特性,例如动态SQL、一级缓存、二级缓存、日志管理、多表级联查询、批处理等
MyBatis官网:https://mybatis.org/mybatis-3/zh/index.html
Github官网:https://github.com/mybatis/mybatis-3/releases
1.2 MyBatis环境搭建
1.2.1 创建测试表
create database test;
use test;
drop table if exists emp;
CREATE TABLE `emp` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '员工姓名',
`age` int(11) NULL DEFAULT NULL COMMENT '员工年龄',
`addr` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '籍贯',
`salary` decimal(10, 2) NULL DEFAULT NULL COMMENT '薪资',
PRIMARY