亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dbutils.java

?? DWR 3級聯動代碼 基于DWR 的整合 是一個不錯的例子
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package com.zhangwei.db;

import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.Reader;
import java.io.Writer;
import java.math.BigDecimal;
import java.sql.Blob;
import java.sql.CallableStatement;
import java.sql.Clob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Types;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;

import oracle.jdbc.OracleResultSet;
import oracle.sql.BLOB;
import oracle.sql.CLOB;

public class DBUtils {

	private static Properties props;

	static {
		props = new Properties();
		// mysql
		props.put("driver_class", "com.mysql.jdbc.Driver");
		props.put("url", "jdbc:mysql://localhost:3306/bank");
		props.put("username", "root");
		props.put("password", "root");

		// sql2005
//		props.put("driver_class", "com.microsoft.sqlserver.jdbc.SQLServerDriver");
//		props.put("url", "jdbc:sqlserver://localhost:1433;databaseName=petshop4;selectMethod=cursor");
//		props.put("username", "sa");
//		props.put("password", "sa");

		// oracle
//		props.put("driver_class", "oracle.jdbc.OracleDriver");
//		props.put("url", "jdbc:oracle:thin:@localhost:1521:XE");
//		props.put("username", "scott");
//		props.put("password", "tiger");
		
		// sql jtds
//		props.put("driver_class", "net.sourceforge.jtds.jdbc.Driver");
//		props.put("url", "jdbc:jtds:sqlserver://localhost:1433/pubs");
//		props.put("username", "sa");
//		props.put("password", "sa");	

		// odbc
		// props.put("driver_class", "sun.jdbc.odbc.JdbcOdbcDriver");
		// props.put("url", "jdbc:odbc:test");
	}

	private static DBUtils me = new DBUtils();

	private DBUtils() { }

	public static DBUtils getInstance() { return me; }
	
	private static ThreadLocal<Connection> localConn = new ThreadLocal<Connection>();

	/**
	 * 打開一個新的Connection
	 * @return
	 */
	public Connection openConnection() {
		Connection conn = null;
		try {
			Class.forName(props.getProperty("driver_class"));
			conn = DriverManager.getConnection(
					props.getProperty("url"), 
					props.getProperty("username"), 
					props.getProperty("password"));
			conn.setAutoCommit(false);
		} catch (Exception e) {
			throw new RuntimeException("不能獲得連接", e);
		}
		return conn;
	}
	
	/**
	 * 釋放ResultSet,Statement資源,請注意參數順序應為ResultSet -> Statement
	 * 注意Connection不需要你作為參數傳入
	 */
	public void closeAll(Object... objects) {
		if(objects != null) {
			for (int i = 0; i < objects.length; i++) {
				Object o = objects[i];
				if(o == null) continue;
				if(o instanceof ResultSet) { closeRs((ResultSet)o); }
				else if (o instanceof Statement) { closeStmt((Statement)o); }
				else { throw new RuntimeException("錯誤的資源類型,只能是ResultSet,Statement"); }
			}
		}
		closeCurrentConnection();
	}
	
	public void closeAll() {
		closeAll(null);
	}
	
	public void closeRs(ResultSet rs) {
		try { if(rs != null) rs.close(); rs = null; } catch (SQLException e) { }
	}
	
	public void closeStmt(Statement stmt) {
		try { if(stmt != null) stmt.close(); stmt = null; } catch (SQLException e) { }
	}
	
	private void closeConn(Connection conn) {
		try { if(conn != null) conn.close(); conn = null; } catch (SQLException e) { }
	}
	
	/**
	 * 獲得與當前線程相關的Connection,如果當前已有,則用此Connection
	 * @return
	 */
	public Connection getCurrentConnection() {
		Connection conn = localConn.get();
		if(conn == null){
			conn = openConnection();
			localConn.set(conn);
		}
		return conn;
	}
	
	/**
	 * 關閉當前線程相關的Connection
	 *
	 */
	private void closeCurrentConnection() {
		Connection conn = localConn.get();
		if(conn != null) {
			closeConn(conn);
			localConn.set(null);
		}
	}
	
	/**
	 * 提交事務,當業務方法執行成功后調用
	 *
	 */
	public void commit() {
		Connection conn = getCurrentConnection();
		try { conn.commit(); } catch (SQLException e) { }
	}
	
	/**
	 * 回滾事務,當業務方法執行出現異常后調用
	 *
	 */
	public void rollback() {
		Connection conn = getCurrentConnection();
		try { conn.rollback(); } catch (SQLException e) { }
	}
	
	private int getSqlType(Object o) {
		if (o == null) return Types.NULL;
		if(o instanceof String) {
			return Types.VARCHAR;
		} else if(o instanceof Boolean) {
			return Types.BOOLEAN;
		} else if (o instanceof Integer) {
			return Types.INTEGER;
		} else if (o instanceof Long) {
			return Types.BIGINT;
		} else if (o instanceof Float) {
			return Types.FLOAT;
		} else if (o instanceof Double) {
			return Types.DOUBLE;
		} else if (o instanceof BigDecimal) {
			return Types.NUMERIC;
		} else if (o instanceof Date) {
			return Types.TIMESTAMP;
		} else if (o instanceof Short) {
			return Types.SMALLINT;
		} else if (o instanceof InputStream) { // 僅通過sql server 2005 的測試
			return Types.BINARY;
		}else {
			throw new RuntimeException("沒有此類型");
		}
	}
	
	/**
	 * 執行增刪改語句,返回影響行數
	 * @param sql
	 * @param params
	 * @return
	 */
	public int executeUpdate (String sql, Object... params) {
		Connection conn = getCurrentConnection();
		PreparedStatement pstmt = null;
		try {
			pstmt = conn.prepareStatement(sql);
			parseParameters(pstmt, params);
			return pstmt.executeUpdate();
		} catch (SQLException e) {
			throw new RuntimeException("執行增刪改時失敗",e);
		} finally {
			closeStmt(pstmt);
		}
	}

	private void parseParameters(PreparedStatement pstmt, Object... params) throws SQLException {
		if(params != null){
			for(int index = 0; index < params.length; index++ ){
				Object o = params[index];
				if(o == null){
					pstmt.setObject(index+1, null);
				} else {
					pstmt.setObject(index+1, o, getSqlType(o));
				}
			}
		}
	}
	
	/**
	 * 執行增刪改語句,返回影響行數
	 * 配合prepare方法使用,適用于執行批量操作
	 * @param pstmt
	 * @param params
	 * @return
	 */
	public int executeUpdate (PreparedStatement pstmt, Object... params) {
		try {
			parseParameters(pstmt, params);
			return pstmt.executeUpdate();
		} catch (SQLException e) {
			throw new RuntimeException("執行增刪改時失敗",e);
		}
	}
	
	public PreparedStatement prepare(String sql) {
		Connection conn = getCurrentConnection();
		PreparedStatement pstmt = null;
		try {
			pstmt = conn.prepareStatement(sql);
			return pstmt;
		} catch (SQLException e) {
			throw new RuntimeException("創建Statement失敗",e);
		}
	}
	
	public void addBatch (PreparedStatement pstmt, Object... params) {
		try {
			parseParameters(pstmt, params);
			pstmt.addBatch();
		} catch (SQLException e) {
			throw new RuntimeException("執行增刪改時失敗",e);
		}
	}
	
	public void executeBatch(PreparedStatement pstmt){
		try {
			pstmt.executeBatch();
		} catch (SQLException e) {
			throw new RuntimeException("執行批處理時出錯",e);
		}
	}
	
	
	/**
	 * 執行查詢,返回ResultSet,注意必須由調用者負責關閉
	 * @param sql
	 * @param params
	 * @return
	 */
	public ResultSet executeQuery (String sql, Object... params) {
		Connection conn = getCurrentConnection();
		try {
			PreparedStatement pstmt = conn.prepareStatement(sql);
			parseParameters(pstmt, params);
			return pstmt.executeQuery();
		} catch (SQLException e) {
			throw new RuntimeException("執行查詢時失敗",e);
		} 
	}
	
	/**
	 * 執行查詢,返回ResultSet,注意必須由調用者負責關閉
	 * 配合prepare方法使用,適用于執行批量操作
	 * @param sql
	 * @param params
	 * @return
	 */
	public ResultSet executeQuery (PreparedStatement pstmt, Object... params) {
		try {
			parseParameters(pstmt, params);
			return pstmt.executeQuery();
		} catch (SQLException e) {
			throw new RuntimeException("執行查詢時失敗",e);
		} 
	}
	
	/**
	 * 根據異常判斷是否是因為資源被其他會話以NOWAIT方式鎖定
	 * 僅用于Oracle
	 * @param e
	 * @return
	 */
	public boolean checkIsLock (Exception e) {
		if(e == null) {
			return false;
		} 
		if(e instanceof SQLException) {
			SQLException se = (SQLException)e.getCause();
			return (se.getErrorCode() == 54);// 資源被其他會話以NOWAIT方式鎖定
		}
		Exception cause = (Exception)e.getCause();
		if(cause != null) {
			if(cause instanceof SQLException) {
				SQLException se = (SQLException)cause.getCause();
				return (se.getErrorCode() == 54);// 資源被其他會話以NOWAIT方式鎖定
			}
		}
		return false;
	}
	
	class IgnoreCaseHashMap extends HashMap {

		@Override
		public Object put(Object key, Object value) {
			return super.put(key.toString().toLowerCase(), value);
		}

		@Override
		public Object get(Object key) {
			return super.get(key.toString().toLowerCase());
		}
		
	}
	
	public List list (String sql, Object... params) {
		Connection conn = getCurrentConnection();
		PreparedStatement pstmt = null;
		ResultSet rs = null;
		try {
			pstmt = conn.prepareStatement(sql);
			parseParameters(pstmt, params);
			rs = pstmt.executeQuery();
			ResultSetMetaData rsmd = rs.getMetaData();
			int columnCount = rsmd.getColumnCount();
			List total = new ArrayList();
			while(rs.next()) {
				Map m = new IgnoreCaseHashMap();
				for(int i = 0; i < columnCount; i++) {
					parseResultSet(rs, rsmd, m, i+1);
				}
				total.add(m);
			}
			return total;
		} catch (SQLException e) {
			throw new RuntimeException("執行查詢時失敗",e);
		} finally {
			closeRs(rs);
			closeStmt(pstmt);
		}
	}

	private void parseResultSet(ResultSet rs, ResultSetMetaData rsmd, Map m, int index) throws SQLException {
		String columnName = rsmd.getColumnName(index);
		// 針對日期統一返回java.util.Date,針對整數統一返回Integer,小數統一返回BigDecimal
		if(rsmd.getColumnType(index) == Types.DATE || 
				rsmd.getColumnType(index) == Types.TIME || 
				rsmd.getColumnType(index) == Types.TIMESTAMP) {
			m.put(columnName, getUtilDate(rs.getTimestamp(columnName)));
		} else if (rsmd.getColumnType(index) == Types.SMALLINT || 
				rsmd.getColumnType(index) == Types.INTEGER || 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩三级免费观看| 欧美一区二区三级| 国产福利91精品| 久久99久久精品| 久草中文综合在线| 国产精品18久久久久久久久| 国产精品一卡二卡在线观看| 国产成人精品免费| 成人免费毛片aaaaa**| 成人免费视频caoporn| av在线综合网| 欧美在线观看18| 欧美日韩国产一区二区三区地区| 欧美日韩一区二区三区四区五区| 欧美日韩免费观看一区三区| 日韩精品一区国产麻豆| 久久久久久97三级| 中文字幕中文字幕在线一区| 亚洲精品视频免费看| 亚洲一区二区三区国产| 日韩成人免费看| 国产精品白丝jk黑袜喷水| 成人久久18免费网站麻豆 | 国产成a人无v码亚洲福利| 成人永久看片免费视频天堂| 91色视频在线| 日韩视频一区二区在线观看| 国产欧美一区二区精品性色| 一区二区三区欧美激情| 日本怡春院一区二区| 国产精品一级片| 欧美在线|欧美| 精品国产免费一区二区三区四区 | av电影一区二区| 欧美日韩在线免费视频| 337p粉嫩大胆噜噜噜噜噜91av| 国产精品福利电影一区二区三区四区| 亚洲一级电影视频| 国产成人精品亚洲777人妖| 欧美日韩精品一区视频| 日本一区二区成人在线| 日韩中文字幕麻豆| 91在线观看污| 欧美mv日韩mv国产网站app| 一区二区三区日韩在线观看| 国产在线精品免费| 欧美色图天堂网| 日本一区二区三区四区在线视频| 亚洲电影第三页| 91亚洲资源网| 国产亚洲欧美中文| 美女视频一区二区| 欧美日韩一区不卡| 亚洲精品视频自拍| 成人高清av在线| 精品91自产拍在线观看一区| 天天操天天综合网| 在线观看亚洲成人| 中文字幕亚洲综合久久菠萝蜜| 久久不见久久见中文字幕免费| 91久久精品一区二区三| 国产精品视频线看| 成人中文字幕电影| 久久只精品国产| 精品一区二区国语对白| 欧美高清激情brazzers| 亚洲一区二区黄色| 欧美性猛交一区二区三区精品| 国产精品美日韩| 成人深夜视频在线观看| 亚洲国产高清不卡| 成人毛片在线观看| 亚洲天堂免费在线观看视频| 成人爱爱电影网址| 最新高清无码专区| 91视频在线观看免费| 樱桃视频在线观看一区| 欧美午夜精品免费| 香蕉乱码成人久久天堂爱免费| 欧美特级限制片免费在线观看| 亚洲精品视频观看| 欧美色国产精品| 奇米精品一区二区三区在线观看| 欧美色网站导航| 热久久久久久久| 精品成人一区二区| 不卡的av在线播放| 亚洲另类在线视频| 欧美一级夜夜爽| 国产一区二区视频在线播放| 国产精品麻豆久久久| 91色porny蝌蚪| 亚洲国产综合在线| 欧美成人性战久久| av在线综合网| 日韩av在线发布| 国产视频一区二区三区在线观看| 成人性生交大合| 一区二区三区精品久久久| 91麻豆精品国产91久久久更新时间| 免费人成黄页网站在线一区二区| 久久亚洲一级片| 91色在线porny| 精品在线视频一区| 亚洲色图丝袜美腿| 日韩一区二区三区在线观看 | 亚洲日本欧美天堂| 欧美男人的天堂一二区| 国产精品一区不卡| 亚洲福利视频三区| 亚洲国产成人一区二区三区| 欧美图片一区二区三区| 精品一区二区在线观看| 一区二区三区小说| 久久久久久久久久久久久久久99| 色狠狠色狠狠综合| 国产精品综合av一区二区国产馆| 玉足女爽爽91| 国产精品污www在线观看| 91精品国模一区二区三区| av电影在线观看不卡| 激情综合色丁香一区二区| 亚洲婷婷综合久久一本伊一区| 日韩一区二区三区观看| 色综合久久综合网97色综合| 老司机午夜精品| 亚洲成人久久影院| 亚洲美腿欧美偷拍| 国产精品人成在线观看免费 | 国产精品系列在线播放| 日韩中文字幕不卡| 亚洲国产日韩一级| 亚洲少妇屁股交4| 亚洲国产精华液网站w| 精品成人在线观看| 欧美一级片在线| 欧美日韩精品专区| 欧美亚洲精品一区| 97久久精品人人澡人人爽| 懂色av一区二区夜夜嗨| 国产精品一卡二| 国产成人亚洲精品狼色在线 | 波多野结衣中文字幕一区二区三区| 蜜桃视频在线一区| 舔着乳尖日韩一区| 亚洲国产cao| 亚洲国产视频一区二区| 一区二区免费看| 一区二区国产盗摄色噜噜| 亚洲男人的天堂在线aⅴ视频| 国产精品女人毛片| 国产精品家庭影院| 亚洲欧美国产高清| 亚洲影视在线播放| 亚洲永久免费av| 婷婷丁香久久五月婷婷| 蜜臀av性久久久久蜜臀aⅴ流畅| 午夜精品福利一区二区蜜股av | 欧美午夜片在线看| 在线一区二区三区四区| 欧美老肥妇做.爰bbww| 7777精品伊人久久久大香线蕉| 在线电影欧美成精品| 欧美一级一区二区| 久久久另类综合| 中文字幕视频一区| 亚洲亚洲精品在线观看| 日韩avvvv在线播放| 久久精品99久久久| 国产精品2024| 色八戒一区二区三区| 欧美精品自拍偷拍| 亚洲精品在线观看网站| 中文字幕精品在线不卡| 一区二区三区产品免费精品久久75| 午夜亚洲福利老司机| 国产一区91精品张津瑜| 一本色道**综合亚洲精品蜜桃冫| 欧美日韩国产综合一区二区| 精品少妇一区二区三区在线播放| 中文字幕不卡在线观看| 亚洲va在线va天堂| 国产资源精品在线观看| 91香蕉视频污在线| 日韩欧美在线网站| 亚洲乱码国产乱码精品精98午夜| 视频一区中文字幕| av不卡免费电影| 欧美成人伊人久久综合网| 亚洲丝袜美腿综合| 激情五月婷婷综合| 欧美视频一区二区三区| 久久久精品2019中文字幕之3| 亚洲一区在线视频观看| 国产激情偷乱视频一区二区三区| 欧美三级韩国三级日本一级| 久久精品夜色噜噜亚洲aⅴ| 性做久久久久久久免费看| 国产成人午夜电影网| 日韩视频在线你懂得|