通过JDBC连接数据库(二)

本文详细介绍了如何创建一个JDBCUtil类,用于管理数据库连接、预编译语句和结果集的获取与释放。通过静态初始化加载数据库驱动,提供了一个简洁的接口来获取数据库连接,并确保资源的正确关闭。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这次是建一个JDBCUtil类,代码如下:

package com.huawei;

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

/**
 * @author zhangzhao
 *
 * 2012-2-17下午08:53:27
 */
public final class JDBCUtil {
	private static	String url="jdbc:mysql://localhost:3306/jdbc";
	private static String user="root";
	private static String password="root";
	private JDBCUtil()
	{
		
	}
	static{
		try {
			Class.forName("com.mysql.jdbc.Driver");
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	public static Connection getConnection() throws SQLException{
		return DriverManager.getConnection(url, user, password);
	}
	public static void free(ResultSet rs,PreparedStatement pStatement,Connection conn){
		
		try {
			if(rs!=null){
				rs.close();
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally{
			try {
				if(pStatement!=null)
					pStatement.close();
			} catch (Exception e2) {
				// TODO: handle exception
			}
			finally{
				if(conn!=null)
					try {
						conn.close();
					} catch (SQLException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
			}
			
		}
		
	}


}

主函数如下:

package com.huawei;

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

/**
 * @author zhangzhao
 *
 * 2012-2-17下午08:39:25
 */
public class JDBCTest {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		template();
	}
	public static void template()
	{
		Connection conn=null;
		PreparedStatement pStatment=null;
		ResultSet rs=null;
		try {
			conn=JDBCUtil.getConnection();
			pStatment=conn.prepareStatement("select * from user");
			rs=pStatment.executeQuery();
			while(rs.next()){
				System.out.println(rs.getObject(1)+"\t"+rs.getObject(2)+"\t"+rs.getObject(3)+"\t"+rs.getObject(4));
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		finally{
			//释放
			JDBCUtil.free(rs, pStatment, conn);
	}

}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值