传统的JDBC开发如下步骤如下:
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来操作数据,存在如下几个问题:
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
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