一、引言

在 Java 开发中,与数据库的交互是一项常见且重要的任务。JDBC(Java Database Connectivity)作为 Java 语言访问数据库的标准 API,为我们提供了统一的接口来操作各种数据库。然而,每次进行数据库操作都编写大量重复的代码,如加载驱动、获取连接、释放资源等,不仅繁琐,还容易出错。因此,我们通常会封装一个 JDBC 工具类来简化这些操作。本文将详细介绍我所编写的三个不同版本的 JDBC 工具类,分别是基础版(1.0)、优化版(2.0)和连接池版(3.0)。

二、基础版(1.0):JDBCUtilsO

2.1 代码实现

package com.qcby;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;public class JDBCUtilsO {/*** 加载驱动的方法 static*/public static void loadDriver() {try{Class.forName("com.mysql.cj.jdbc.Driver");}catch(Exception e){e.printStackTrace();}}//获取链接public static Connection getconnect() {loadDriver();Connection conn = null;try{conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/jdbcdemo", "root", "123456");} catch (Exception e) {e.printStackTrace();}return conn;}//释放资源public static void close(Connection conn, Statement stmt, ResultSet rs) {if(rs != null) {try{rs.close();} catch (Exception e) {e.printStackTrace();}}if(stmt != null) {try{stmt.close();} catch (Exception e) {e.printStackTrace();}}if(conn != null) {try{conn.close();}catch (Exception e) {e.printStackTrace();}}}
}

2.2 代码分析

  • 加载驱动:通过Class.forName("com.mysql.cj.jdbc.Driver")加载 MySQL 的 JDBC 驱动。
  • 获取连接:使用DriverManager.getConnection方法获取数据库连接,需要硬编码数据库的 URL、用户名和密码。
  • 释放资源:依次关闭ResultSetStatementConnection对象,确保资源被正确释放。

2.3 优缺点

  • 优点:代码简单易懂,适合初学者理解 JDBC 的基本操作流程。
  • 缺点
    • 数据库连接信息硬编码在代码中,不利于维护和修改。
    • 每次获取连接都需要重新加载驱动,效率较低。

三、优化版(2.0):JdbcUtils

3.1 代码实现

package com.qcby;import java.io.InputStream;
import java.sql.*;
import java.util.Properties;public class JdbcUtils {private static final String driverclass;private static final String url;private static final String username;private static final String password;static {//加载属性文件Properties prop = new Properties();InputStream in = JdbcUtils.class.getClassLoader().getResourceAsStream("jdbc.properties");if (in == null) {System.out.println("找不到配置文件");}try{prop.load(in);} catch (Exception e) {e.printStackTrace();}//给常量赋值driverclass = prop.getProperty("driverclass");url = prop.getProperty("url");username = prop.getProperty("username");password = prop.getProperty("password");}/***     加载驱动*/public static void loadDriver() throws ClassNotFoundException, SQLException {try{//加载驱动类Class.forName(driverclass);}catch (ClassNotFoundException e){e.printStackTrace();}}/*** 获取链接 返回链接对象* @return*/public static Connection getConnection() {//加载驱动//获取到链接对象,返回连接对象;Connection conn = null;try {conn = DriverManager.getConnection(url, username, password);} catch (SQLException e) {e.printStackTrace();}return conn;}public static void close(Connection conn, Statement stmt, ResultSet rs) {if (rs != null) {try {rs.close();} catch (Exception e) {e.printStackTrace();}}if (stmt != null) {try{stmt.close();}catch (Exception e){e.printStackTrace();}}if (conn != null) {try{conn.close();} catch (Exception e) {e.printStackTrace();}}}
}

 

3.2 代码分析

  • 配置文件加载:通过Properties类加载jdbc.properties配置文件,将数据库连接信息存储在配置文件中,避免了硬编码。
  • 静态代码块:在类加载时执行静态代码块,确保驱动只加载一次。
  • 获取连接:从配置文件中读取数据库连接信息,使用DriverManager.getConnection方法获取连接。

3.3 优缺点

  • 优点
    • 数据库连接信息存储在配置文件中,便于维护和修改。
    • 驱动只加载一次,提高了效率。
  • 缺点:每次获取连接都需要创建新的连接对象,频繁创建和销毁连接会消耗大量的系统资源。

 

四、连接池版(3.0):JDBCUtilsC

4.1 代码实现

package com.qcby;import com.alibaba.druid.pool.DruidDataSourceFactory;import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;public class JDBCUtilsC {//连接池对象private static DataSource DATA_SOURCE;static {//加载属性文件Properties prop = new Properties();InputStream input = JDBCUtilsC.class.getClassLoader().getResourceAsStream("jdbc.properties");try{//加载属性文件prop.load(input);//创建连接池对象DATA_SOURCE = DruidDataSourceFactory.createDataSource(prop);}catch(Exception e){e.printStackTrace();}}/*** 从连接池中获取链接,返回*/public static Connection getConnection() {Connection conn = null;try{conn = DATA_SOURCE.getConnection();} catch (Exception e) {e.printStackTrace();}return conn;}public static void close(Connection conn, Statement stmt, ResultSet rs){if(rs != null){try {rs.close();} catch (SQLException e) {e.printStackTrace();}}if(stmt != null){try {stmt.close();} catch (SQLException e) {e.printStackTrace();}}if(conn != null){try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}
}

 

4.2 代码分析

  • 连接池的使用:使用阿里巴巴的 Druid 连接池,通过DruidDataSourceFactory.createDataSource方法创建连接池对象。
  • 获取连接:从连接池中获取连接,而不是每次都创建新的连接对象。
  • 释放资源:关闭连接时,实际上是将连接归还给连接池,而不是真正的关闭。

4.3 优缺点

  • 优点
    • 连接池可以复用连接对象,减少了频繁创建和销毁连接的开销,提高了系统的性能。
    • 连接池可以对连接进行管理,如连接的超时、最大连接数等,提高了系统的稳定性。
  • 缺点:引入了第三方依赖,增加了项目的复杂度。

五、总结

通过对三个不同版本的 JDBC 工具类的介绍,我们可以看到,随着版本的升级,工具类的性能和可维护性都得到了显著的提升。基础版适合初学者了解 JDBC 的基本操作,优化版通过配置文件和静态代码块提高了代码的可维护性和效率,而连接池版则通过连接池的使用进一步提高了系统的性能和稳定性。在实际开发中,我们应该根据项目的需求选择合适的版本。

希望本文对你理解 JDBC 工具类的优化过程有所帮助。如果你有任何问题或建议,欢迎在评论区留言。

以上博客围绕 JDBC 工具类的三个版本展开,从基础版逐步优化到连接池版,详细介绍了每个版本的代码实现、代码分析和优缺点,希望能满足你的需求。你可以根据实际情况进行调整和修改。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/86646.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/86646.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/86646.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实验室建设案例 | 洛阳职业技术学院—人工智能实验室

院校简介 洛阳职业技术学院位于千年古都、牡丹花城、丝路起点洛阳,是一所由洛阳市政府举办的公办高职院校,成立于2011年,办学历史可追溯到1945年的豫西公学。学校全面贯彻党的教育方针,围绕落实立德树人根本任务,秉承“…

vue2中,修改对象数组中元素对应的属性,页面不更新的问题解决

有如下代码: // 有一个数组 let dataAry [{name: haha, age: 20},{name: hello, age: 21} ] // 这个数组在模板中使用了v-for进行循环 v-for"one of dataAry" :name"one.name" :address"one.address"// 子组件中使用如下&#xff…

代理模式:控制对象访问的守门员[特殊字符],优雅实现功能增强与访问控制!

代理模式:控制对象访问的守门员🔐,优雅实现功能增强与访问控制! 文章目录 代理模式:控制对象访问的守门员🔐,优雅实现功能增强与访问控制!前言:为什么需要代理&#xff1…

《人间词话》PPT课件

《人间词话》简介 《人间词话》是王国维所著的一部文学批评著作。《人间词话》作于1908~1909年,最初发表于《国粹学报》。该作是作者接受了西洋美学思想之洗礼后,以崭新的眼光对中国旧文学所作的评论。 《人间词话》PPT课件下载 夸克网盘分享…

解剖智能运维三基石:Metrics/Logs/Traces

3秒知识卡 三基石关系: Metrics(指标)→ 系统脉搏(CPU/错误率) Logs(日志)→ 事件日记(错误堆栈/用户行为) Traces(追踪)→ 血缘地图(…

从代码学习深度学习 - 情感分析:使用卷积神经网络 PyTorch版

文章目录 前言加载数据集一维卷积最大时间汇聚层textCNN模型定义模型加载预训练词向量训练和评估模型总结前言 在之前的章节中,我们探讨了如何使用循环神经网络(RNN)来处理序列数据。今天,我们将探索另一种强大的模型——卷积神经网络(CNN)——并将其应用于自然语言处理…

深入解析分布式训练基石:ps-lite源码实现原理

分布式机器学习框架是现代推荐、广告和搜索系统的核心支撑。面对海量训练数据和高维稀疏特征,参数服务器(Parameter Server, PS) 架构应运而生。作为早期经典实现的ps-lite因其简洁性和完整性,成为理解PS原理的绝佳切入点。本文将…

IDEA 插件开发:Internal Actions 与 UI Inspector 快速定位 PSI

在开发 IntelliJ 平台插件的过程中,你常常需要搞清楚 某个 IDE 弹框背后是如何操作 PSI(Program Structure Interface) 的。下面这篇笔记将介绍如何通过 Internal Actions、UI Inspector 以及调试技巧快速定位 PSI 调用链。 1. 启用 Internal…

26考研|数学分析:多元函数微分学

前言 本章我们将进行多元函数微分学的学习,多元函数微分学与一元函数微分学相对应,涉及到可微性、中值定理、泰勒公式等诸多问题的探讨与研究,本章难度较大,在学习过程中需要进行深度思考与分析,才能真正掌握这一章的…

数星星--二分

https://www.matiji.net/exam/brushquestion/17/4498/F16DA07A4D99E21DFFEF46BD18FF68AD 二分思路不难&#xff0c;关键的区间内个数的确定 #include<bits/stdc.h> using namespace std; #define N 100011 #define inf 0x3f3f3f3f typedef long long ll; typedef pair&…

Oracle/PostgreSQL/MSSQL/MySQL函数实现对照表

函数列表清单 函数作用OraclePOSTGRESQLMSSQLMYSQL求字符串长度LENGTH(str)LENGTH(str)LEN(str)LENGTH(str)字符切割SUBSTR(str,index,length)SUBSTR(str,index,length)SUBSTRING(str,index,length)SUBSTRING(str,index,length)字符串连接str1||str2||str3...strNstr1||str2||…

pycharm客户端安装教程

二、 pycharm客户端安装 打开pycharm官网&#xff1a;https://www.jetbrains.com/pycharm/download/?sectionwindows 选择其他版本 选择2018社区版本&#xff0c;点击下载 双击下载的安装程序(第一个弹框允许)&#xff0c;选择下一步 更改安装路径&#xff0c;在pycah…

博图SCL语言中用户自定义数据类型(UDT)使用详解

博图SCL语言中用户自定义数据类型&#xff08;UDT&#xff09;使用详解 一、UDT概述 用户自定义数据类型&#xff08;UDT&#xff09;是TIA Portal中强大的结构化工具&#xff0c;允许将多个相关变量组合成单一数据结构。UDT本质是可重用的数据模板&#xff0c;具有以下核心优…

Vscode自定义代码快捷方式

首选项>配置代码片段 >新建全局代码片段 (也可以选择你的语言 为了避免有的时候不生效 选择全局代码) {"console.log": { //名字"prefix": "log",//prefix 快捷键 &#xff1a; log"body": ["console.log($1);", //b…

ESP32 008 MicroPython Web框架库 Microdot 实现的网络文件服务器

以下是整合了所有功能的完整 main.py(在ESP32 007 MicroPython 适用于 Python 和 MicroPython 的小型 Web 框架库 Microdot基础上)&#xff0c;实现了&#xff1a; Wi‑Fi 自动连接&#xff08;支持静态 IP&#xff09;&#xff1b;SD 卡挂载&#xff1b;从 /sd/www/ 读取 HTML…

Mcp-git-ingest Quickstart

目录 配置例子 文档github链接&#xff1a;git_ingest.md 配置 {"mcpServers": {"mcp-git-ingest": {"command": "uvx","args": ["--from", "githttps://github.com/adhikasp/mcp-git-ingest", "…

(LeetCode 面试经典 150 题) 27.移除元素

目录 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; 思路&#xff1a; 核心思路&#xff1a; 思路详解&#xff1a; 样例模拟&#xff1a; 代码&#xff1a; C代码&#xff1a; Java代码&#xff1a; 题目&#xff1a; 题目描述&#xff1a; 题目链接…

MySQL之事务原理深度解析

MySQL之事务原理深度解析 一、事务基础&#xff1a;ACID特性的本质1.1 事务的定义与核心作用1.2 ACID特性的内在联系 二、原子性与持久性的基石&#xff1a;日志系统2.1 Undo Log&#xff1a;原子性的实现核心2.2 Redo Log&#xff1a;持久性的保障2.3 双写缓冲&#xff08;Dou…

JUC:5.start()与run()

这两个方法都可以使线程进行运行&#xff0c;但是start只能用于第一次运行线程&#xff0c;后续要继续运行该线程需要使用run()方法。如果多次运行start()方法&#xff0c;会出现报错。 初次调用线程使用run()方法&#xff0c;无法使线程运行。 如果你对一个 Thread 实例直接调…

微服务中解决高并发问题的不同方法!

如果由于流量大而在短时间内几乎同时发出请求&#xff0c;或者由于服务器不稳定而需要很长时间来处理请求&#xff0c;并发问题可能会导致数据完整性问题。 示例问题情况 让我们假设有一个逻辑可以检索产品的库存并将库存减少一个&#xff0c;如上所述。此时&#xff0c;两个请…