news 2026/5/7 21:50:48

javaWeb从入门到进阶(MyBatis)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
javaWeb从入门到进阶(MyBatis)

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

JDBC:
(Java DataBase Connectivity),就是使用Java语言操作关系型数据库的一套API。

sun公司官方定义的一套操作所有关系型数据库的规范,即接口。
各个数据库厂商去实现这套接口,提供数据库驱动jar包。
我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。

原始的JDBC

1.开发效率低下

  • 80%的时间在写重复的JDBC模板代码

  • 只有20%的时间在写业务逻辑

2.代码维护困难

  • SQL分散在Java代码各处

  • 数据库变更需要修改大量文件

  • 难以进行单元测试

3.容易产生bug

  • 资源泄露(忘记关闭连接)

  • SQL注入漏洞

  • 类型转换错误

  • 事务管理错误

4.性能瓶颈

  • 频繁创建数据库连接

  • SQL无法预编译和重用

  • 没有缓存机制

尽管有这么多缺点,原始JDBC在以下场景仍有价值:

  1. 性能要求极高的场景:需要精细控制SQL执行

  2. 极简项目:小工具、原型验证

  3. 学习目的:理解底层原理

  4. 特殊数据库操作:存储过程、批量处理等

原始的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


Lombok是一个实用的Java类库,能通过注解的形式自动生成构造器、getter/setter、equals、hashcode、toString等方法,并可以自动化生成日志变量,简化java开发、提高效率。

添加依赖

<dependency>
<groupId>org.projectlombok</groupId><artifactId>lombok</artifactId>
</dependency>

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/5 10:40:24

GPEN从零开始部署教程:Docker镜像拉取与运行指令详解

GPEN从零开始部署教程&#xff1a;Docker镜像拉取与运行指令详解 1. 为什么选择GPEN做肖像增强&#xff1f; 你有没有遇到过这些情况&#xff1a;老照片泛黄模糊、手机拍的人像噪点多、证件照不够清晰、社交平台上传的自拍细节丢失……传统修图软件要么操作复杂&#xff0c;要…

作者头像 李华
网站建设 2026/4/22 10:19:09

2026年AI自动化入门必看:Open-AutoGLM手机智能体部署全解析

2026年AI自动化入门必看&#xff1a;Open-AutoGLM手机智能体部署全解析 你有没有想过&#xff0c;以后手机操作不再需要手动点来点去&#xff1f;比如想查天气、订外卖、找资料&#xff0c;只要说一句“帮我打开高德地图查最近的咖啡馆”&#xff0c;手机就自动完成整个流程—…

作者头像 李华
网站建设 2026/5/5 19:06:09

如何利用智能工具实现网络资源的高效获取与自动化批量处理

如何利用智能工具实现网络资源的高效获取与自动化批量处理 【免费下载链接】E-Hentai-Downloader Download E-Hentai archive as zip file 项目地址: https://gitcode.com/gh_mirrors/eh/E-Hentai-Downloader 在数字资源爆炸的时代&#xff0c;高效获取和管理网络资源已…

作者头像 李华
网站建设 2026/5/7 16:18:04

Qwen3-1.7B多轮对话实现:上下文管理部署步骤详解

Qwen3-1.7B多轮对话实现&#xff1a;上下文管理部署步骤详解 你是否试过刚问完“上一个问题的答案是什么”&#xff0c;模型却一脸茫然&#xff1f;或者连续聊了五轮&#xff0c;它突然把前两轮的关键信息全忘了&#xff1f;这不是模型“健忘”&#xff0c;而是上下文管理没做…

作者头像 李华
网站建设 2026/5/4 12:02:56

Paraformer-large批量转写任务队列:Celery集成部署案例

Paraformer-large批量转写任务队列&#xff1a;Celery集成部署案例 1. 为什么需要任务队列&#xff1f;——单次Gradio界面的局限性 你已经成功跑通了Paraformer-large语音识别离线版&#xff0c;上传一段30秒的采访录音&#xff0c;点击“开始转写”&#xff0c;几秒钟后文字…

作者头像 李华