• 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();
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    我们之前一直使用的是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 
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
  • 相关阅读:
    数据库安全如何保障?YashanDB有妙招(上篇)
    pandas基础-pandas之Series+ 读取外部数据+dataframe+dataframe的索引
    入门力扣自学笔记123 C++ (题目编号768)
    RabbitMQ 利用DelayExchange插件实现延迟队列
    消除springboot+thymeleaf时页面的红色波浪线告警
    ChatGPT推出全新功能,引发人工智能合成声音担忧|百能云芯
    rust学习——操作字符串、字符串转义、操作UTF8-字符串 (操作中文字符串)
    低密度奇偶校验码LDPC(十)——LDPC码的密度进化
    【CSS】字体图标与favicon图标
    服务发现原理分析与源码解读
  • 原文地址:https://blog.csdn.net/Bb15070047748/article/details/127872619