01【MyBatis-快速入门】

54 阅读3分钟

一、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官网:mybatis.org/mybatis-3/z…