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

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

?? dbdao.java

?? 是一個Bug系統
?? JAVA
字號:
package com.runwit.ebookstore.services.dao;

import java.io.IOException;
import java.math.BigDecimal;
import java.sql.Connection;
import java.sql.Date;
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.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public abstract class DbDAO {
	static {
		try {
			Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
			System.out.println("JDBC驅動加載成功!");
		} catch (ClassNotFoundException cnf) {
			cnf.printStackTrace();
		}
	}

	protected Connection conn;

	protected PreparedStatement pstmt;

	protected Statement stmt;

	protected ResultSet rs;

	private String url = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=book";

	private String userName = "shen";

	private String userPwd = "shen";

	protected DbDAO() {
		try {
			DbConfig config = DbConfig.getInstance();
			url = config.getUrl();
			userName = config.getUserName();
			userPwd = config.getUserPwd();

		} catch (IOException ex) {
			System.err.println("加載數據庫配置文件失敗");
			ex.printStackTrace();
		}
	}

	protected void openConnection() throws SQLException {
		if (conn == null)
			conn = DriverManager.getConnection(url, userName, userPwd);

	}

	protected void openStatement() throws SQLException {
		if (stmt == null)
			stmt = conn.createStatement();
	}

	protected void openPreparedStatement(String sql) throws SQLException {
		if (pstmt == null)
			pstmt = conn.prepareStatement(sql);

	}

	protected void closeConnection() {
		try {
			conn.close();
		} catch (SQLException ex) {
			ex.printStackTrace();
		} finally {
			conn = null;
		}
	}

	protected void closeStatement() {
		try {
			stmt.close();
		} catch (SQLException ex) {
			ex.printStackTrace();
		} finally {
			stmt = null;
		}

	}

	protected void closePreparedStatement() {
		try {
			pstmt.close();
		} catch (SQLException ex) {
			ex.printStackTrace();
		} finally {
			pstmt = null;
		}

	}

	public int updateBySql(String sql) throws SQLException {
		try {
			openConnection();
			openStatement();
			DebugUtil.printSql(sql);
			return stmt.executeUpdate(sql);

		} finally {
			closeStatement();
			closeConnection();
		}
	}

	public int updateBySql(String sql, Object[] paramValues, int[] types)
			throws SQLException {
		try {
			DebugUtil.printSql(sql);
			openConnection();
			openPreparedStatement(sql);

			// 參數綁定

			for (int i = 0; i < paramValues.length; i++) {
				bindingParam(pstmt, i + 1, paramValues[i], types[i]);
			}

			return pstmt.executeUpdate();

		} finally {
			closePreparedStatement();
			closeConnection();
		}

	}

	public void openResultSet(String sql) throws SQLException {
		rs = stmt.executeQuery(sql);
	}

	public void openResultSet(Object[] paramValues, int[] types)
			throws SQLException {
		// 參數綁定
		for (int i = 0; i < paramValues.length; i++) {
			bindingParam(pstmt, i + 1, paramValues[i], types[i]);
		}
		rs = pstmt.executeQuery();
	}

	public void closeResultSet() {
		try {
			if (rs != null) {
				rs.close();
			}
		} catch (SQLException ex) {
			ex.printStackTrace();
		} finally {
			rs = null;
		}
	}

	public List queryToMap(String sql) {
		List alRet = new ArrayList();
		try {
			openConnection();
			openStatement();
			openResultSet(sql);
			ResultSetMetaData meta = rs.getMetaData();
			int colCount = meta.getColumnCount();

			while (rs.next()) {
				Map m = new HashMap();
				for (int i = 1; i <= colCount; i++)
					m.put(meta.getColumnName(i).toLowerCase(), rs.getObject(i));
				alRet.add(m);
			}
			return alRet;

		} catch (SQLException ex) {
			ex.printStackTrace();
		} finally {
			closeResultSet();
			closeStatement();
			closeConnection();
		}

		return alRet;

	}
	
	public long getMaxID(String columnName, String tableName) {
		List result = queryToMap("select max("+columnName+") as maxid from "+tableName);
		if(result.size() > 0) {
			HashMap m = (HashMap)result.get(0);
			Object val = m.get("maxid");
			if(val != null) {
				return ((Long)val).longValue();
			}
		}
		return -1;
	}

	public List queryToMap(String sql, Object[] paramValues, int[] types) {
		List alRet = new ArrayList();
		try {
			openConnection();
			openPreparedStatement(sql);
			openResultSet(paramValues, types);
			ResultSetMetaData meta = rs.getMetaData();
			int colCount = meta.getColumnCount();

			while (rs.next()) {
				Map m = new HashMap();
				for (int i = 1; i <= colCount; i++)
					m.put(meta.getColumnName(i).toLowerCase(), rs.getObject(i));
				alRet.add(m);
			}
			return alRet;

		} catch (SQLException ex) {
			ex.printStackTrace();
		} finally {
			closeResultSet();
			closePreparedStatement();
			closeConnection();
		}

		return alRet;

	}

	private void bindingParam(PreparedStatement pstmt, int idx, Object val,
			int type) throws SQLException {
		switch (type) {
		case SHORT_TYPE:
			pstmt.setShort(idx, ((Short) val).shortValue());
			break;
		case INT_TYPE:
			pstmt.setInt(idx, ((Integer) val).intValue());
			break;
		case STRING_TYPE:
			pstmt.setString(idx, val.toString());
			break;
		case OBJECT_TYPE:
			pstmt.setObject(idx, val);
			break;
		case DATE_TYPE:
			pstmt.setDate(idx, (Date) val);
			break;
		case BYTEARRAY_TYPE:
			pstmt.setBytes(idx, (byte[])val);
			break;
		case BIGDECIMAL_TYPE:
			pstmt.setBigDecimal(idx, (BigDecimal)val);
			break;
		}
	}

	public List queryRowToMap(String sql) throws SQLException {
		System.out.println(sql);
		try {
			openConnection();
			openStatement();
			ResultSet rs = stmt.executeQuery(sql);
			ResultSetMetaData meta = rs.getMetaData();
			int columnCount = meta.getColumnCount(); // 列總數
			System.out.println("列總數:" + columnCount);
			List alRet = new ArrayList();
			while (rs.next()) {
				HashMap rowMap = new HashMap();
				for (int i = 1; i <= columnCount; i++) {
					String columnName = meta.getColumnName(i).toLowerCase(); // 列名
					Object obj = rs.getObject(i);// 列值
					rowMap.put(columnName, obj);
				}
				alRet.add(rowMap);
			}
			return alRet;
		} finally {
			closeStatement();
			closeConnection();
		}
	}

	public List queryBySql(String sql) throws SQLException {
		System.out.println(sql);
		try {
			openConnection();
			openStatement();
			ResultSet rs = stmt.executeQuery(sql);
			ResultSetMetaData meta = rs.getMetaData();
			int columnCount = meta.getColumnCount(); // 列總數
			System.out.println("列總數:" + columnCount);
			List alRet = new ArrayList();
			while (rs.next()) {
				alRet.add(mapRowToModel(rs));
//				HashMap rowMap = new HashMap();
//				for (int i = 1; i <= columnCount; i++) {
//					String columnName = meta.getColumnName(i).toLowerCase(); // 列名
//					Object obj = rs.getObject(i);// 列值
//					rowMap.put(columnName, obj);
//				}
//				alRet.add(rowMap);
			}
			return alRet;
		} finally {
			closeStatement();
			closeConnection();
		}
	}

	public static final int SHORT_TYPE = 1;

	public static final int INT_TYPE = 2;

	public static final int LONG_TYPE = 3;

	public static final int STRING_TYPE = 4;

	public static final int OBJECT_TYPE = 5;

	public static final int DATE_TYPE = 6;
	
	public static final int BYTEARRAY_TYPE = 7;
	
	public static final int BIGDECIMAL_TYPE = 8;
	
	public abstract Object mapRowToModel(ResultSet rs) throws SQLException;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产高清一区二区三区| 韩国成人福利片在线播放| 99久久99久久精品免费看蜜桃| 国产欧美日韩一区二区三区在线观看| 国产精选一区二区三区| 久久久精品国产免费观看同学| 大胆亚洲人体视频| 亚洲精品国产无天堂网2021 | 亚洲五月六月丁香激情| 欧美美女网站色| 看片网站欧美日韩| 国产亲近乱来精品视频| 一本大道av一区二区在线播放| 一区二区三区成人在线视频| 91麻豆精品国产91久久久使用方法 | 欧美乱妇23p| 国产一区二区三区在线观看免费视频 | 在线免费观看一区| 麻豆精品国产传媒mv男同| 久久久99精品免费观看不卡| 91麻豆国产自产在线观看| 日韩电影一二三区| 国产精品午夜在线观看| 在线观看一区二区精品视频| 青草av.久久免费一区| 中日韩免费视频中文字幕| 欧美午夜片在线看| 国产成人综合视频| 日韩精品色哟哟| 国产精品久久久久影院| 欧美日韩一区二区三区四区| 狠狠狠色丁香婷婷综合激情 | 国产三级一区二区三区| 在线观看中文字幕不卡| 国产精品综合一区二区| 亚洲成av人片在线| 国产精品色哟哟| 精品久久久久久久久久久久久久久 | 国产精品一级在线| 亚洲成人午夜电影| 中文字幕日韩一区二区| 精品国产一区二区亚洲人成毛片| 欧美在线免费观看亚洲| 成人中文字幕电影| 麻豆91精品91久久久的内涵| 亚洲精品欧美专区| 欧美激情一区二区三区不卡| 日韩一区二区三区免费观看| 一本色道久久综合精品竹菊| 国产精品一区免费视频| 日韩精品午夜视频| 亚洲五码中文字幕| 亚洲天堂免费看| 欧美激情资源网| 久久综合99re88久久爱| 日韩欧美www| 欧美日韩在线免费视频| 91久久线看在观草草青青| 成人精品视频一区二区三区| 久久精品国产99国产| 偷拍自拍另类欧美| 亚洲午夜一区二区三区| 亚洲三级在线播放| 国产精品久久久久精k8| 国产婷婷色一区二区三区四区| 日韩欧美久久一区| 亚洲欧洲av色图| 国产精品污网站| 日韩视频一区二区三区 | 欧美一区二区视频观看视频| 一本到高清视频免费精品| 高潮精品一区videoshd| 国产一区二区日韩精品| 韩国av一区二区三区四区| 九色综合狠狠综合久久| 久久爱www久久做| 久99久精品视频免费观看| 久久不见久久见免费视频7| 久久99国产精品成人| 精品一区二区在线观看| 国产一区二区三区四| 国产精品自拍在线| 不卡的av电影| 在线观看日韩高清av| 欧美性猛交xxxxxx富婆| 欧美日韩一区二区三区不卡| 欧美区在线观看| 欧美一区二区三区日韩视频| 日韩欧美美女一区二区三区| 欧美tk—视频vk| 国产日产欧产精品推荐色| 国产喂奶挤奶一区二区三区| 国产精品热久久久久夜色精品三区| 国产精品久久久久久久久免费桃花 | 日韩欧美久久久| 国产日韩欧美综合一区| 国产精品国产馆在线真实露脸| 亚洲精品国产无天堂网2021| 午夜精品一区在线观看| 国产综合成人久久大片91| fc2成人免费人成在线观看播放| 97se亚洲国产综合自在线不卡| 日本韩国欧美国产| 日韩免费看的电影| 欧美国产激情二区三区| 亚洲香肠在线观看| 久久国产精品无码网站| 99久久精品一区二区| 欧美日本韩国一区二区三区视频| 精品久久久久久久人人人人传媒| 国产精品国模大尺度视频| 亚洲午夜精品网| 国产一区激情在线| 欧美中文字幕一二三区视频| 欧美xxxx在线观看| 亚洲欧美成人一区二区三区| 免费高清视频精品| 99久久国产综合色|国产精品| 91 com成人网| 国产精品不卡在线| 麻豆精品一区二区三区| 99视频超级精品| 日韩免费高清视频| 亚洲一区二区视频在线观看| 国产精品亚洲综合一区在线观看| 在线观看不卡一区| 日本一区二区三区国色天香| 亚洲成a人v欧美综合天堂下载| 国产激情一区二区三区| 91精品婷婷国产综合久久性色 | 精品一区精品二区高清| 在线观看日产精品| 国产亚洲欧洲997久久综合| 亚洲大型综合色站| 99久久免费视频.com| 久久婷婷一区二区三区| 五月天久久比比资源色| 色综合久久88色综合天天免费| 久久奇米777| 免费高清成人在线| 欧美日韩精品专区| 亚洲激情第一区| 99视频一区二区三区| 亚洲精品在线一区二区| 午夜精品久久久久久久久久| www.日韩在线| 欧美激情一区二区三区在线| 久久精品国产色蜜蜜麻豆| 欧美精品久久天天躁| 亚洲精品乱码久久久久久久久| 国产成人精品免费网站| 久久亚洲一区二区三区四区| 美女视频一区二区| 欧美二区乱c少妇| 五月婷婷激情综合| 欧美嫩在线观看| 亚洲国产精品麻豆| 欧美日韩视频专区在线播放| 一区二区在线观看视频| 91色porny在线视频| 中日韩免费视频中文字幕| 懂色一区二区三区免费观看 | 欧美一区二区三区视频| 青椒成人免费视频| 91精品国产综合久久婷婷香蕉| 亚洲一区二区三区四区五区中文| 色伊人久久综合中文字幕| 国产精品久久久久久久久搜平片 | 欧美日免费三级在线| 一级特黄大欧美久久久| 欧美色综合久久| 亚洲二区在线观看| 欧美日韩二区三区| 欧美aa在线视频| 精品国产一区二区三区久久影院| 六月丁香婷婷色狠狠久久| 2022国产精品视频| 成人在线一区二区三区| 国产精品第13页| 在线看国产一区| 日本欧美一区二区三区乱码| 欧美大黄免费观看| 粉嫩高潮美女一区二区三区 | 97久久精品人人爽人人爽蜜臀| 亚洲欧洲日产国产综合网| 色婷婷香蕉在线一区二区| 亚洲成人av电影| 精品久久一区二区| 成人美女视频在线观看18| 亚洲女人****多毛耸耸8| 欧美影院精品一区| 蜜臀久久99精品久久久画质超高清| 精品国产乱码久久久久久影片| 国产精品538一区二区在线| 国产精品福利一区二区| 日本精品一级二级| 精品一区二区三区香蕉蜜桃 | 国产亲近乱来精品视频| 色欧美88888久久久久久影院| 婷婷开心激情综合|