01【MyBatis-快速入门】

一、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 
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

緑水長流*z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值