日期:2014-05-16  浏览次数:20446 次

jdbc 小封装

菜鸟写的JDBC封装,望前辈指出不足地方!

先介绍一下功能: 1.数据库连接地址从配置文件中获取

??????????????????????????2.支持命名参数设置(如: select? * from t_user where f_userName = :username)

??????????????????????????3.批量插入、更新?使用同一个connncetion

使用:

?

public class StockSend {
 Log LOG = LogFactory.getLog(StockSend.class);
 WarningEnvironment env = new WarningEnvironment();
 SaveRemind send = new SaveRemind();
 MySqlUtil mySqlUtil = new MySqlUtil(env.db_stock_warning, env.DB_STOCK_USER, env.DB_STOCK_PASSWORD);
 public List<StockSendUser> sendAllUser(){
  List<StockSendUser> stockSends = new ArrayList<StockSendUser>();
  String sql = "select * from db_stock_warning.t_warning_task where f_send_state = 0";
  stockSends = mySqlUtil.queryForList(sql, callBack);
  return stockSends;
 }
 MysqlQueryCallBack callBack = new MysqlQueryCallBack() {//查询对象封装回调接口
  
  @Override
  public Object next(ResultSet rs) throws Exception {
   StockSendUser stock = new StockSendUser();
   stock.setUin(rs.getString("f_uin"));
   stock.setStock_code(rs.getString("f_stock_code"));
   stock.setStock_name(rs.getString("f_stock_name"));
   stock.setPrice(rs.getDouble("f_price"));
   stock.setStock_higher(rs.getDouble("f_stock_higher"));
   stock.setStock_less(rs.getDouble("f_stock_less"));
   return stock;
  }
 };
 public void updateStockSend(StockSendUser stock){
  String sql="update from db_stock_warning.t_warning_task set f_send_state = 1 where f_uin= ? and f_date= ? and f_stock_code=? and f_price = ? ";
  
  mySqlUtil.insertOrUpdate(sql, parameter, stock);
 }
 MysqlParameterCallBack parameter = new MysqlParameterCallBack() {//参数设置回调接口
  
  @Override
  public void setParameter(PreparedStatement ps, Object o) throws Exception {
   StockSendUser stock = (StockSendUser)o;
   int i=1;
   ps.setString(i++, stock.getUin());
   ps.setString(i++, stock.getDate());
   ps.setString(i++, stock.getStock_code());
   ps.setDouble(i++, stock.getPrice());
   
  }
 }; 

 

 

核心类:

package com.tenpay.fund.util.pub.JDBC;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
 *  jdbc连接 处理类
 * @author W_xieqi
 *
 */
public class MySqlUtil {
 private final String mysql_url;
 private final String user ;
 private final String password ;
 private  Log log = LogFactory.getLog(MySqlUtil.class);
 
 public MySqlUtil(String mysql_url,String user,String password ) {
  this.mysql_url= mysql_url;
  this.user = user;
  this.password = password;
 }
 //获得连接
 public  Connection getConnection() {
  // 建立连接
  Connection con = null;
  try {
   if (con == null || con.isClosed()) {
    Class.forName("com.mysql.jdbc.Driver");//这里应该也应该放到配置文件中 
    con = DriverManager.getConnection(mysql_url, user,
      password);
   }
  } catch (Exception e) {
   log.error("re create connection error", e);
  }
  return con;
 }
 /**
  * 关闭连接方法
  */
 public  void closeConnection(Connection con){
  try {
   //连接不为空,并且连接未关闭
   if(con !=null && !con.isClosed()){
    con.close();
   }
  } catch (SQLException e) {
   
   log.error("close connection error", e);
  }
 }
 /**
  * 关闭PreparedStatement
  */
 public  void closePreparedStatement(PreparedStatement ps){
  try {
   if(ps != null && !ps.isClosed()){
    ps.close();
   }
  } catch (SQLException e) {
   
   log.error("close PreparedStatement  excption",e);
  }
 }
 /**
  * 关闭PreparedStatement
  */
 public  void closeNamedParameterStatement(NamedParameterStatement ps){
  try {
   if(ps != null ){
    ps.close();
   }
  } catch (SQLException e) {
   
   log.error("closeNamedParameterStatement  excption",e);
  }
 }
 /**
  * 关闭PreparedStatement
  */
 public  void closeResultSet(ResultSet rs){
  try {
   if(rs != null && !rs.isClosed()){
    rs.close();
   }