
MyBatis是一款优秀的持久层框架,用于简化JDBC的开发。MyBatis本是Apache的一个开源项目iBatis, 2010年这个项目由apache迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github。 官网: https://mybatis.org/mybatis-3/zh/index.html

使用Mybatis查询所有用户数据 1.准备工作(创建springboot工程、数据库表user、实体类User)
2.引入Mybatis的相关依赖,配置Mybatis(数据库的连接信息) 3.编写SQL语句(注解/XML)
第一步准备工作

数据库表和实体类(javabean)
之后在application.properties类中配置数据库连接信息
#驱动类名称 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver #数据库连接的url spring.datasource.url=jdbc:mysql://localhost:3306/mybatis #连接数据库的用户名 spring.datasource.username=root #连接数据库的密码 spring.datasource.password=1234
之后创建接口Mapper
并在前面加上@Mapper,这样在运行时,会自动生成该接口的实现类对象(代理对象),并且将该对象交给IOC容器管理。
在单元测试中,我们要想用这个接口的对象,肯定不能通过new一个接口,但是上面我们通过@Mapper,这样在运行时,会自动生成该接口的实现类对象(代理对象),并且将该对象交给IOC容器管理,已经成为IOC容器中的bean了,在单元测试中,我们可以通过依赖注入的方式把这个bean对象注入进来。
JDBC: (Java DataBase Connectivity),就是使用Java语言操作关系型数据库的一套API。

sun公司官方定义的一套操作所有关系型数据库的规范,即接口。 各个数据库厂商去实现这套接口,提供数据库驱动jar包。 我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。
原始的JDBC
尽管有这么多缺点,原始JDBC在以下场景仍有价值:
原始的JDBC就像是"手写汇编语言"操作数据库,虽然灵活但效率低下。MyBatis等框架就像是"高级编程语言",通过封装和抽象,让开发者能更专注于业务逻辑而不是底层细节。
对比

数据库连接池 数据库连接池是个容器,负责分配、管理数据库连接(Connection) 它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个 释放空闲时间超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏
优势 资源重用 提升系统响应速度 避免数据库连接遗漏
数据库连接池 标准接口:DataSource 官方(sun)提供的数据库连接池接口,由第三方组织实现此接口。 功能:获取连接 Connection getConnection () throws SQLException;
切换Druid数据库连接池 官方地址: https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter <dependency> <groupld>com.alibaba</groupld> <artifactid>druid-spring-boot-starter</artifactid> <version>1.2.8</version> </dependency> pom.xml
Lombok是一个实用的Java类库,能通过注解的形式自动生成构造器、getter/setter、equals、hashcode、toString等方法,并可以自动化生成日志变量,简化java开发、提高效率。

添加依赖
<dependency> <groupId>org.projectlombok</groupId><artifactId>lombok</artifactId> </dependency>