SQL数据库连接工具类

package cn.itcast;

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

/**
 * 查询结果处理接口
 * 
 * @author 作者:LiuJunGuang
 * @version 创建时间:2011-11-10 下午07:26:41
 */
interface ResultSetHander {
	Object hander(ResultSet rs);
}

/**
 * 类说明:数据库连接和释放
 * 
 * @author 作者: LiuJunGuang
 * @version 创建时间:2011-11-6 上午11:49:14
 */
public class JDBCUtils {
	private static String driver = "com.mysql.jdbc.Driver";
	private static String url = "jdbc:mysql://localhost:3306/chat";
	private static String user = "root";
	private static String password = "root";
	private static Connection con = null;
	// 注册驱动
	static {
		try {
			Class.forName(driver);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
	}

	// 创建连接
	public static Connection getConnection() {
		if (con == null) {
			try {
				con = DriverManager.getConnection(url, user, password);
			} catch (SQLException e) {
				throw new RuntimeException(e);
			}
		}
		return con;
	}

	// 关闭连接
	public static void colse(ResultSet rs, Statement st, Connection con) {
		if (rs != null) {
			try {
				rs.close();
			} catch (SQLException e) {
				throw new RuntimeException(e);
			}
		}
		if (st != null) {
			try {
				st.close();
			} catch (SQLException e) {
				throw new RuntimeException(e);
			}
		}
		if (con != null) {
			try {
				con.close();
			} catch (SQLException e) {
				throw new RuntimeException(e);
			}
		}
	}

	// 更新数据库
	public static void update(String sql, Object[] params) {
		Connection con = JDBCUtils.getConnection();
		Statement stmt = null;
		ResultSet rs = null;
		try {
			PreparedStatement ps = con.prepareStatement(sql);
			ParameterMetaData psm = ps.getParameterMetaData();// 获得查询语句的元数据信息
			int paramNum = psm.getParameterCount();// 得到参数的总个数
			for (int i = 1; i <= paramNum; i++) {
				ps.setObject(i, params[i - 1]);
			}
			ps.executeUpdate();
		} catch (SQLException e) {
			throw new RuntimeException(e);
		} finally {
			JDBCUtils.colse(rs, stmt, con);
		}
	}

	// 查询数据库
	public static Object query(String sql, Object[] params, ResultSetHander rsh) {
		Connection con = JDBCUtils.getConnection();
		Statement stmt = null;
		ResultSet rs = null;
		try {
			PreparedStatement ps = con.prepareStatement(sql);
			ParameterMetaData psm = ps.getParameterMetaData();// 获得查询语句的元数据信息
			int paramNum = psm.getParameterCount();// 得到参数的总个数
			for (int i = 1; i <= paramNum; i++) {
				ps.setObject(i, params[i - 1]);
			}
			rs = ps.executeQuery();
			return rsh.hander(rs);
		} catch (SQLException e) {
			throw new RuntimeException(e);
		} finally {
			JDBCUtils.colse(rs, stmt, con);
		}
	}
}
package cn.itcast;

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

import org.junit.Test;

/**
 * 类说明:数据库操作类
 * 
 * @author 作者: LiuJunGuang
 * @version 创建时间:2011-11-6 下午12:02:36
 */
public class JDBCUtilsTest {
	@Test
	public void find() {
		String sql = "select * from history";

		JDBCUtils.query(sql, null, new ResultSetHander() {
			@Override
			public Object hander(ResultSet rs) {
				try {
					while (rs.next()) {
						System.out.println(rs.getString("username"));
					}
				} catch (SQLException e) {
					e.printStackTrace();
				}
				return null;
			}
		});
	}

	@Test
	public void update() {
		String sql = "delete from history where id = ?";
		Object obj[] = { 1 };
		JDBCUtils.update(sql, obj);
	}

	@Test
	public void find2() {
		Connection con = JDBCUtils.getConnection();
		PreparedStatement st = null;
		ResultSet rs = null;
		try {
			String find = "select * from history where username=? and action=?";
			st = con.prepareStatement(find);
			st.setString(1, "nihao");
			st.setString(2, "微笑着");
			rs = st.executeQuery();
			while (rs.next()) {
				System.out.println(rs.getString("username"));
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			JDBCUtils.colse(rs, st, con);
		}
	}
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.hexiang.utils; /** * SQLUtils utils = new SQLUtils(User.class); utils.setWhereStr("", "id", "=", 100).setWhereStr("and", "name", " ", "is null").setWhereStr("and", "date", ">=", new Date()); utils.setOrderByStr("id", "desc").setOrderByStr("name", "asc"); System.out.println(utils.buildSelectSQL()); System.out.println(utils.buildCountSQL()); */ import java.sql.Timestamp; import java.text.SimpleDateFormat; import java.util.Date; import java.util.LinkedHashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; public class SqlUtils { private String beanName; private String beanShortName; private Map propertyMap; private List conditionList; private List relationList; private Map orderByMap; public SqlUtils(Class instance) { this.setBeanName(instance.getSimpleName()); this.setBeanShortName(Character.toLowerCase(this.getBeanName() .charAt(0)) + ""); init(); } public SqlUtils() { init(); } void init(){ propertyMap = new LinkedHashMap(); conditionList = new LinkedList(); relationList = new LinkedList(); orderByMap = new LinkedHashMap(); } /** * 添加查询条件 * * @param relation * 关联 "and","or"等 * @param property * 查询的对象属性 * @param condition * 查询的条件,关系符 * @param value * 查询的值 */ public SqlUtils setWhereStr(String relation, String property, String condition, Object value) { if(value != null){ relationList.add(relation); propertyMap.put(property, value); conditionList.add(condition); } return this; } private String buildWhereStr() { StringBuffer buffer = new StringBuffer(); if (!propertyMap.isEmpty() && propertyMap.size() > 0) { buffer.append("WHERE 1 = 1 "); int index = 0; for (String property : propertyMap.keySet()) { if (property != null && !property.equals("")) { buffer.append(r

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值