创建JDBCUtils工具类
JDBCUtils工具类
- 私有化构造函数,外界无法直接创建对象
- 提供公共的,静态的,getConnection 方法,用来给外界提供数据库连接
- 提供公共的,静态的,close方法,用来释放资源
package cn.tedu.util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ResourceBundle;
/**
* 这个类用来提供jdcb的工具类
1.1 私有化构造函数,外界无法直接创建对象
1.2 提供公共的,静态的,getConnection 方法,用来给外界提供数据库连接
1.3 提供公共的,静态的,close方法,用来释放资源
1.4 测试类
*/
public class JDBCUtils {
//1,私有化构造函数,外界无法直接创建对象
private JDBCUtils(){}
//只加载一次属性文件
static ResourceBundle rb = null;
static{
//a,,,,读取属性文件
rb = ResourceBundle.getBundle("jdbc");
}
//2,提供公共的,静态的,getConnection 方法,
//用来给外界提供数据库连接
public static Connection getConnection(){
try {
//1,注册驱动
//b,,获取属性文件里的内容
Class.forName(rb.getString("driverClass"));
//2,获取数据库连接
String url=rb.getString("jdbcUrl");
String user=rb.getString("user");
String password=rb.getString("password");
Connection conn = DriverManager.getConnection(url, user, password);
return conn;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
//3,提供公共的,静态的,close方法,
//用来释放资源
public static void close(ResultSet rs, Statement st,Connection conn){
//释放结果集资源
//非空判断,防止空指针异常
if(rs!=null){
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}finally{
rs=null;//手动置空
}
}
//释放传输器资源
//非空判断,防止空指针异常
if(st!=null){
try {
st.close();
} catch (SQLException e) {
e.printStackTrace();
}finally{
st=null;//手动置空
}
}
//释放数据库连接资源
//非空判断,防止空指针异常
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}finally{
conn=null;//手动置空
}
}
}
测试类
package cn.tedu.test;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import org.junit.Test;
import com.mysql.jdbc.Driver;
import cn.tedu.util.JDBCUtils;
/**
* 这个类用来测试工具类
*/
public class TestUtils {
//单元测试方法:@Test + void
@Test
public void hello(){
Connection conn = null;//声明连接对象
Statement st = null;//声明传输器对象
ResultSet rs = null;//声明结果集对象
try {
//1,注册驱动 2,获取数据库连接
conn = JDBCUtils.getConnection();
//3,获取传输器java.sql.Statement
st = conn.createStatement();
// 4,执行SQL。java.sql.ResultSet
String sql ="select * from user";
rs = st.executeQuery(sql);
// 5,遍历结果集
while(rs.next()){
//根据列的索引获取第一列的数据
// String id = rs.getString(1);
//根据列的名字获取第一列的数据
String id = rs.getString("id");
// int id1 = rs.getInt(1);
//根据列的索引获取第二列的数据
String username = rs.getString(2);
//根据列的索引获取第三列的数据
String password = rs.getString(3);
System.out.println(id+username+password);
}
} catch (SQLException e) {
e.printStackTrace();
}finally{//保证资源一定会被释放
// 6,释放资源
JDBCUtils.close(rs, st, conn);
}
}
}
准备数据

配置文件的开发形式
//2,提供公共的,静态的,getConnection 方法,
//用来给外界提供数据库连接
public static Connection getConnection(){
try {
//a,,,,读取属性文件
ResourceBundle rb =
ResourceBundle.getBundle("jdbc");
//1,注册驱动
//b,,获取属性文件里的内容
Class.forName(rb.getString("driverClass"));
//2,获取数据库连接
String url=rb.getString("jdbcUrl");
String user=rb.getString("user");
String password=rb.getString("password");
Connection conn =
DriverManager.getConnection(
url, user, password);
return conn;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
创建JDBCUtils工具类的更多相关文章
- JavaWeb基础之JdbcUtils工具类final
JdbcUtils工具类3.0最终版,添加了事务相关功能和释放链接.最终版本可以直接打成jar包,在后面的基本项目都会使用该工具类 1. JdbcUtils代码 /** * 最终版 * @author ...
- JavaWeb基础之JdbcUtils工具类1.0
2016年12月20日,第一次学习JDBC.看的是传智播客崔希凡老师的视频,东北口音很是风趣幽默,技术之牛让人膜拜.2017年9月21日,再次重温web知识,分享JdbcUtils工具类,用以接下来的 ...
- 记一次关于JDBCUtils工具类的编写
jdbc.properties数据库配置的属性文件内容如下 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost/xxxx ...
- Druid 连接池 JDBCUtils 工具类的使用
Druid工具介绍 它不仅仅是一个数据库连接池,它还包含一个ProxyDriver,一系列内置的JDBC组件库,一个SQL Parser. 支持所有JDBC兼容的数据库,包括Oracle.MySQL. ...
- hibernate课程 初探一对多映射2-3 创建hibernateUtil工具类
本节主要内容:创建hibernateUtil工具类:demo demo: HibernateUtil.java package hibernate_001; import org.hibernate. ...
- 【JDBC】学习路径5-提取JDBCUtils工具类
回顾我们上面几节的内容,我们发现重复代码非常多,比如注册驱动.连接.关闭close()等代码,非常繁杂. 于是我们将这些重复的大段代码进行包装.提取成JDBCUtils工具类. 第一章:提取注册连接模 ...
- 01_JavaMail_05_创建邮件工具类MailUtils等方便发送邮件
[工程截图] [代码实现] [Mail.java] package com.Higgin.Utils; import java.util.ArrayList; import java.util.Lis ...
- JavaWeb基础之JdbcUtils工具类2.0
使用c3p0连接池来改版JdbcUtils工具 1. 使用c3p0连接池获取连接,使代码更加简单 /** * 使用c3p0连接池做小工具 * JdbcUtils v2.0 * @author hui. ...
- Java课程设计---创建数据库工具类
1.传统的数据库操作 package com.java.mysql; import java.sql.Connection; import java.sql.DriverManager; import ...
随机推荐
- fuz 2159 WuYou
Problem 2159 WuYou Accept: 16 Submit: 64Time Limit: 1000 mSec Memory Limit : 32768 KB Problem ...
- 性能是.NET Core的一个关键特性
关键要点1).NET Core是跨平台的,可运行在Windows.Linux.Mac OS X和更多平台上:与.NET相比,发布周期要短得多.大多数.NET Core都是通过NuGet软件包交付的,可 ...
- HTTPS 常见部署问题及解决方案
在最近几年里,我写了很多有关 HTTPS 和 HTTP/2 的文章,涵盖了证书申请.Nginx 编译及配置.性能优化等方方面面.在这些文章的评论中,不少读者提出了各种各样的问题,我的邮箱也经常收到类似 ...
- css边框颜色渐变
在实际开发中,我们经常遇见边框需要背景渐变的实现要求,那么如何去实现呢,今天给大家分享依稀几种情况 1.直角的背景渐变 <!DOCTYPE html> <html lang=&quo ...
- 格式化字符串漏洞利用实战之 njctf-decoder
前言 格式化字符串漏洞也是一种比较常见的漏洞利用技术.ctf 中也经常出现. 本文以 njctf 线下赛的一道题为例进行实战. 题目链接:https://gitee.com/hac425/blog_d ...
- Vue 框架-11-介绍src文件流程及根组件app+HBuilder 配置
Vue 框架-11-介绍src文件流程及根组件app+HBuilder 配置 这是上一篇对目录简单介绍: 关于编辑器,可以使用轻量级的 Sublime Text 3,我使用的是 HBuilder, 但 ...
- @transient加在属性前的作用
我们都知道一个对象只要实现了Serilizable接口,这个对象就可以被序列化,java的这种序列化模式为开发者提供了很多便利,我们可以不必关系具体序列化的过程,只要这个类实现了Serilizable ...
- Tomcat6.0下的jsp、servlet和javabean的配置
第一步:下载jdk和tomcat: 第二步:安装和配置你的jdk和tomcat:执行jdk和tomcat的安装程序,然后设置按照路径进行安装即可.1.安装jdk以后,需要配置一下环境变量,在我的电脑- ...
- System.Web.Optimization对脚本和样式表的操作
这个也是本章重点向描述的部分,首先我们可以使用VS2012RC来新建一个MVC4.0项目,版本可以为4.0或4.5.在Global.asax文件代码中,我们发现已经把过滤器,路由器,以及对样式表和脚本 ...
- iOS设计模式 - 责任链
iOS设计模式 - 责任链 原理图 说明 在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链.请求在这个链上传递,直到链上的某一个对象决定处理此请求.发出这个请求的客户端并不知道链 ...