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); } } }

转载于:https://www.cnblogs.com/hibernate3-example/archive/2011/11/10/2492708.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.hexiang.utils.dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.Properties; import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.NamingException; import javax.sql.DataSource; import org.apache.log4j.Logger; public class DBConnection { /** * 获得与数据库的连接 * * @param path * @return Connection */ public static Connection getConn(String classDriver, String url, String user, String pwd) { try { Class.forName(classDriver); return DriverManager.getConnection(url, user, pwd); } catch (ClassNotFoundException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } public static Connection getConn(DataSource dataSource) { try { return dataSource.getConnection(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } public static Connection getConn(String jndiName) { try { Context ctx; ctx = new InitialContext(); DataSource dataSource = (DataSource) ctx.lookup("java:comp/env/" + jndiName); return dataSource.getConnection(); } catch (NamingException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } public static Connection getConn(Properties properties) { try { String driver = properties.getProperty("jdbc.driverClassName"); String url = properties.getProperty("jdbc.url"); String user = properties.getProperty("jdbc.username"); String password = properties.getProperty("jdbc.password"); Class.forName(driver); return DriverManager.getConnection(url, user, password); } catch (ClassNotFoundException ex) { ex.printStackTrace(); } catch (SQLException ex) { ex.printStackTrace(); } return null; } /** * oracle连接 * * @param path * @return Connection */ public static Connection getOracleConn(String
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、付费专栏及课程。

余额充值