实习笔记 —— MyBatis I (MyBatis基础)

本文介绍了MyBatis的基本概念、特点和原理,并通过实例展示了如何使用Navicat安装MySQL数据库,进行JDBC连接与测试。文章详细解释了MyBatis的优势,包括解除SQL与程序的耦合,提供了动态SQL的支持,以及其简单易用的特性。同时,还给出了针对MySQL8和5版本不同的JDBC连接代码示例。
摘要由CSDN通过智能技术生成

系列文章目录

实习笔记 —— Spring基础
实习笔记 —— IOC反转控制(xml配置文件 + 注解)
实习笔记 —— AOP开发I
实习笔记—— AOP开发II(AOP中Advice的类型)



一、什么是MyBatis?

1.基本概念

本是Apache的开源项目iBatis(来源于“internet”和“abatis”的组合),Java持久层的框架,最主要特点是解除sql与程序代码的耦合。

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。

2.MyBatis特点

简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件。易于学习,易于使用。通过文档和源代码,可以比较完全的掌握它的设计思路和实现。

灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。

解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。

提供映射标签,支持对象与数据库的orm字段关系映射。

提供对象关系映射标签,支持对象关系组建维护。

提供xml标签,支持编写动态sql。

3.MyBatis原理图

在这里插入图片描述

二、MySQL与Navicat

今天没讲 MyBatis 的内容,关注点都在 MySQL 与 Navicat 上。

1.MySQL的安装:
收藏了知乎中的详细安装步骤。

2.Navicat安装:
使用老师传的版本,导入老师的数据库的方法:
新建数据库 → 右键点击新建的库 → 选择运行SQL文件 → 选中要导入的数据库 → 点击开始

在这里插入图片描述
上图为连接成功后的Navicat界面,创建的连接名为 mysql,用户为 root,密码为经典六位数字。

3.JDBC测试:
之前一直没整明白,代码也是一知半解。
在这里插入图片描述

①创建MyBatis项目

②导jar包

③编写测试类 JDBCTest:
(测试MySQL 8版本)

package com.high.demo1;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class JDBCTest {

	public static void main(String[] args) {
//		需求:根据id查询用户  select * from user where id=10
		Connection connection = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
//			1、加载驱动 有改动(新增了cj)
			Class.forName("com.mysql.cj.jdbc.Driver");
//			2、获取连接  库名 + 账号名 + 密码 有改动(改库名和密码,新增serverTimezone=UTC)
			connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/spring4?serverTimezone=UTC", "root", "123456");
//			3、获取预处理
			stmt = connection.prepareStatement("select * from user where id= ?");
//			4、设置参数
			stmt.setInt(1, 10);
//			5、执行,得到了结果集
			rs = stmt.executeQuery();
//			6、从结果集中获取结果
			while(rs.next()){
				
				System.out.println(rs.getInt(1)+"--"+rs.getString(2));
//				rs.getInt("id");
			}
		} catch (Exception e) {
			e.printStackTrace();
		}finally {
			try {
				rs.close();
				stmt.close();
				connection.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}
	}
}

测试成功!
在这里插入图片描述
注意注释 1 & 2 中改动的部分

测试MySQL 5版本:

public class JDBCTest {

	public static void main(String[] args) {
//		需求:根据id查询用户  select * from user where id=10
		Connection connection = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
//			1、加载驱动
			Class.forName("com.mysql.jdbc.Driver");
//			2、获取连接
			connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis", "root", "root");
//			3、获取预处理
			stmt = connection.prepareStatement("select * from user where id= ?");
//			4、设置参数
			stmt.setInt(1, 10);
//			5、执行,得到了结果集
			rs = stmt.executeQuery();
//			6、从结果集中获取结果
			while(rs.next()){
				
				System.out.println(rs.getInt(1)+"--"+rs.getString(2));
//				rs.getInt("id");
			}
		} catch (Exception e) {
			e.printStackTrace();
		}finally {
			try {
				rs.close();
				stmt.close();
				connection.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}
	}
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值