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

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

?? jdbc.java

?? webwork study w ebwork study
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package jaction.utility;

import java.util.*;
import java.sql.*;
import javax.sql.DataSource;
import java.lang.reflect.*;


import jaction.datapool.Result;

/**
 *	類名:      JDBC<br>
 *	說明:	    數據庫操作類<br>
 * @author yanger
 * @version 1.0
 */

public class JDBC {


	/**
	 * 資源綁定對象
	 */
	private static  MessageResources resource = MessageResources.getMessageResources("jaction.JactionConfig");
	/**
	 * JTA JNDI 配置名稱
	 */
	public static final String JACTION_DATASOURCE=resource.getMessage("jaction.jndi.datasource");
	
	
	/**
	 * 從連接池中取得一個空閑的數據庫連接
	 * @return  Connection 數據庫連接
	 * @exception  Exception 數據庫異常
	 */
	public static Connection getConnection() throws Exception{

		Connection conn = null;

    	try {
    		javax.naming.InitialContext ctx = new javax.naming.InitialContext();
    		DataSource ds = (DataSource)ctx.lookup(JACTION_DATASOURCE);
    		conn= ds.getConnection();
		} catch (java.lang.SecurityException se) {
			SysLogger.error("JDBC","getConnection","數據庫連接錯誤,描述信息:"+se);
			se.printStackTrace();
			throw se;
        } catch(Exception e) {
         	SysLogger.error("JDBC","getConnection","數據庫連接錯誤,描述信息:"+e);
         	e.printStackTrace();
			throw e;
        }

    	return conn;

  	}


	/**
	 * 釋放一個空閑的數據庫連接至連接池
	 * @param  conn 數據庫連接
	 */
	public static void freeConnection(Connection conn) {

		try{
			conn.close();
    		conn=null;
		}catch(Exception e){
			SysLogger.error("JDBC", "freeConnection","釋放數據庫連接錯誤,描述信息:"+e);
		}

    }


	/**
	 * 設置指定的數據庫連接的提交方式(true/false),并返回該連接
	 * @param  conn Connection
	 * @param  commitFlag 提交方式(true:自動提交/false:非自動提交)
	 * @return  Connection 數據庫連接
	 * @exception  Exception
	 */
	public static Connection setAutoCommit(Connection conn, boolean commitFlag) throws Exception {

		try {
			conn.setAutoCommit(commitFlag);
			return conn;
		} catch (SQLException sx) {
			SysLogger.error("JDBC","setAutoCommit","數據庫錯誤,描述信息:"+sx);
			throw sx;
		}

	}

	//commit connection
	/**
	 * 對指定的連接進行提交
	 * @param  conn 數據庫連接
	 * @exception  Exception
	 */
	public static void commit(Connection conn) throws Exception {

		try {
			conn.commit();
			setAutoCommit(conn, true);
		}catch (SQLException ex){
			SysLogger.error("JDBC","commit","數據庫錯誤,描述信息:"+ex);
			throw ex;
		}

	}

	//rollback connection
	/**
	 * 對指定的連接進行rollback
	 * @param  conn 數據庫連接
	 * @exception  Exception
	 */
	static public void rollback(Connection conn) throws Exception {

		try{
			conn.rollback();
		} catch (SQLException ex) {
           SysLogger.error("JDBC","rollback","數據庫錯誤,描述信息:"+ex);
           throw ex;
		}
	}

	//execute update sql
	/**
	 * 對指定的sql語句進行JDBC的update操作
	 * @param  query update sql語句
	 * @return  返回成功執(zhí)行的記錄數
	 * @exception  Exception
	 */
	static public int executeUpdate(String query) throws Exception{

		Connection conn = getConnection();
		try{
			return executeUpdate(query, conn);
		} catch(Exception e) {
			throw e;
		} finally {
			freeConnection(conn);
		}

	}

	//execute update sql use connection
	/**
	 * 通過指定的連接對指定的sql語句進行JDBC的update操作
	 * @param  query update sql語句
	 * @param  conn 數據庫連接
	 * @return  返回成功執(zhí)行的記錄數
	 * @exception  Exception
	 */
	static public int executeUpdate(String query, Connection conn) throws Exception{

		SysLogger.infoLog(query);

        Statement stmt = null;

		try {
			stmt = conn.createStatement();
			if (conn == null || stmt == null) {
				SysLogger.error("JDBC","executeUpdate","數據庫連接錯誤!");
				return -1;
			}
			int i = stmt.executeUpdate(query);//執(zhí)行數據庫操作
			return i;
		} catch (SQLException ex) {
			SysLogger.error("JDBC","executeUpdate","數據庫執(zhí)行錯誤!" + query + " SQLException : " + ex);
			 throw ex;
			//return -1;
		} finally {
			try{
				stmt.close();
				stmt = null;
			} catch (SQLException se) {
				SysLogger.error("JDBC","executeUpdate","數據庫statement關閉執(zhí)行錯誤!" + se);
				throw se;
			}
		}

	}

	//execute query sql
	/**
	 * 對指定的sql語句進行JDBC的query操作
	 * @param  query query sql語句
	 * @return  Result 查詢結果集
	 * @exception  Exception
	 */
	static public Result executeQuery(String query) throws Exception {

		Connection conn = getConnection();

		try {
			return executeQuery(query, conn);
		} catch (Exception e) {
			throw e;
		} finally {
			freeConnection(conn);
		}


	}

	//execute query sql use connection
	/**
	 * 通過指定的連接對指定的sql語句進行JDBC的query操作
	 * @param  query query sql語句
	 * @param  conn 數據庫連接
	 * @return  Result 查詢結果集
	 * @exception  Exception
	 */
	static public Result executeQuery(String query,Connection conn) throws Exception {

		Statement stmt = null;
		ResultSet rs = null;
		ResultSetMetaData metaData = null;
		Vector rows = new Vector();
		Object newRow[];
		Object objectRows[][];

		stmt = conn.createStatement();

		if (conn == null || stmt == null) {
			SysLogger.error("JDBC","executeQuery","數據庫連接錯誤!");
			return null;
		}

		SysLogger.info("JDBC","executeQuery",query);
		try {
			rs = stmt.executeQuery(query);
			metaData = rs.getMetaData();
			int numberOfColumns =  metaData.getColumnCount();
			String  columnNames[] = new String[numberOfColumns];

			// Get the column names and cache them.
			// Then we can close the connection.
			for(int column = 0; column < numberOfColumns; column++) {
				columnNames[column] = metaData.getColumnLabel(column+1);
			}

			// Get all rows.
			//weigang modify 20021104
			//boolean columnWritten = true;
			rows.addElement(columnNames);
			while (rs.next()) {
				/*if (columnWritten)
				{
					rows.addElement(columnNames);
					columnWritten = false;
				}*/
				newRow = new Object[numberOfColumns];
				for (int i = 1; i <= numberOfColumns; i++) {
					Object obj=rs.getObject(i);
					newRow[i - 1] =(obj instanceof String)?	 (String)obj :obj;
				}
				rows.addElement(newRow);
			}
		} catch (SQLException ex) {
			SysLogger.error("JDBC","executeQuery","數據庫查詢錯誤"+query + " SQLException " + ex);
			throw ex;
		}finally{

			try{
				rs.close();
			}catch (SQLException se) {
				SysLogger.error("JDBC","executeQuery","數據庫resultSet 關閉錯誤:"+se);
				throw se;
			}

			try{
				stmt.close();
			} catch (SQLException se) {
				SysLogger.error("JDBC","executeQuery","數據庫statement關閉錯誤:"+se);
				throw se;
			}
		}

		if (rows.size() == 0) {
			objectRows = null;
		} else {
			objectRows = new Object[rows.size()][];
			for (int i = 0; i < rows.size(); i++) {
				objectRows[i] = (Object[])rows.elementAt(i);
			}
		}

		Result res = new Result(objectRows);

		return res;

	}

	/**
	 * 對指定的sql語句進行JDBC的query操作,返回從結果集中指定行開始的指定記錄數
     *
     * @param	query	數據庫查詢sql語句
     * @param	beginRows 查詢結果的起始位置
     * @param  pageRows 查詢記錄數
     * @return  Result 查詢結果集
	 * @exception  Exception
     */
  	/*weigang modify 20021104*/
    static public Result executeQuery(String query, int beginRows, int pageRows ) throws Exception{
		try {
			if (beginRows <=0 || pageRows <= 0) {
				throw new Exception("beginRows <=0 || pageRows <= 0");
			}

			Result res = executeQuery(query);	//查詢結果集

			if (res == null) {
     			return res;
          	}

			int rowNumber = res.rowNum();	//結果集二位數組的行數
			int colNumber = res.colNum();	//結果集二位數組的列數

			if (rowNumber <= beginRows) {
				return null;	//沒有符合條件的查詢結果
         	}

       		Object[][] oArray = res.getData();	//結果集二維數組

         	/*從結果集中得到需要的記錄*/
          	Object[][] newArray;
          	if (rowNumber < beginRows + pageRows - 1) {
  				newArray = new Object[rowNumber - beginRows + 2][];
          	} else {
          			newArray = new Object[pageRows + 1][];
          	}

          	newArray[0] = res.getColumnName();

          	for (int i = 1; i < newArray.length; i++) {
          		newArray[i] = oArray[beginRows + i - 2];
          	}

 			Result newRes = new Result(newArray);
			return newRes;
      	} catch (Exception e) {
			throw e;
		}
	}

	/**
	 * 根據表名和Where條件建立查詢語句
	 * @param  tableName 表名
	 * @param  whereStmt where條件
	 * @return  生成的查詢語句
	 * @exception  Exception
	 */
	public static String queryStatementFromClass(String tableName, String whereStmt)throws Exception{
		if(tableName==null){
            throw new Exception("tableName==null");
        }

		//Class resultClass=getClassFromTableName(tableName);
		String  [] fields=getFieldFromTableName(tableName);
		String uStmt="select ";
		for(int i=0;i<fields.length;i++)
		{
			if(i!=0)uStmt += ", ";
			uStmt += fields[i]+" ";
		}
		uStmt += " FROM "+tableName;

		if(whereStmt!=null)
		{
			uStmt += " where " + whereStmt ;
		}
		return uStmt;
	}

	/**
	 * 根據名字, 返回類對象。
	 * @param  tableName 表的名字。
	 * @return  類對象的名字。
	 * @exception  Exception
	 */
	public static Class getClassFromTableName(String tableName)throws Exception{
		// 是否定制

		String strClassName = tableName;
		//if (strClassName.equals(tableName)) strClassName = tableName;
		return Class.forName("jaction.resource."+strClassName);
	}

	/**
	 * 根據表名稱得到所有字段名稱
	 * @param  tableName 表的名字
	 * @return  字段數組
	 * @exception  Exception
	 * @add by zjh 2002-11-1
	 */
	public static String[] getFieldFromTableName(String tableName) throws Exception{
		Connection          connection = null;
		Statement           statement = null;
		ResultSet           resultSet = null;
		ResultSetMetaData   metaData = null;
		int i=0;
		try {
			connection = getConnection();
			statement = connection.createStatement();
			resultSet = statement.executeQuery("Select * from "+tableName);
			if (resultSet == null){
				throw new Exception("resultSet == null");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚州韩日在线看免费版国语版| 欧美精品三级在线观看| 欧美午夜一区二区| 久久久一区二区| 香蕉成人啪国产精品视频综合网| 国产精品一区二区在线播放 | 日韩国产欧美三级| 成人av网址在线| 久久一二三国产| 丝袜亚洲另类丝袜在线| 91女人视频在线观看| 国产天堂亚洲国产碰碰| 另类小说欧美激情| 337p亚洲精品色噜噜噜| 亚洲图片你懂的| 国产精品一线二线三线精华| 91麻豆精品国产91久久久久久久久| 亚洲天堂av一区| 成a人片国产精品| 国产精品天干天干在观线| 极品瑜伽女神91| 欧美videossexotv100| 日本特黄久久久高潮| 欧美理论在线播放| 五月婷婷欧美视频| 91国在线观看| 亚洲在线成人精品| 在线免费观看视频一区| 夜夜嗨av一区二区三区网页| 在线观看不卡一区| 亚洲国产cao| 欧美精品久久99久久在免费线 | 欧美一区二区视频在线观看| 亚洲成人综合在线| 欧美疯狂性受xxxxx喷水图片| 亚洲综合激情另类小说区| 91捆绑美女网站| 亚洲精品日韩综合观看成人91| 99riav久久精品riav| 亚洲精品成人在线| 精品视频一区 二区 三区| 午夜精品久久久久久久| 日韩一区二区三区电影| 国内精品写真在线观看| 久久精品亚洲国产奇米99| 成人精品免费视频| 亚洲综合久久av| 91精品啪在线观看国产60岁| 韩国视频一区二区| 亚洲欧美一区二区在线观看| 在线视频国内自拍亚洲视频| 天天做天天摸天天爽国产一区 | 欧美大片日本大片免费观看| 国内精品免费**视频| 亚洲视频在线观看三级| 欧美日韩中文精品| 蜜桃精品在线观看| 国产午夜亚洲精品理论片色戒| 99久久伊人久久99| 亚洲va天堂va国产va久| 久久久久久久综合色一本| 色综合天天做天天爱| 久久超碰97中文字幕| 亚洲欧洲精品一区二区三区| 欧美精品日韩精品| 国产成a人无v码亚洲福利| 亚洲成人免费在线| 久久精品欧美一区二区三区不卡 | 欧美激情综合五月色丁香小说| av成人老司机| 奇米影视在线99精品| 国产精品久久看| 91精品黄色片免费大全| 国产福利精品导航| 亚洲一区二区美女| 国产精品天干天干在线综合| 欧美一区二区三区啪啪| a4yy欧美一区二区三区| 麻豆国产欧美日韩综合精品二区| 中文乱码免费一区二区| 欧美在线不卡视频| 成人综合在线观看| 日本不卡一二三区黄网| 中文字幕乱码日本亚洲一区二区| 欧美精品久久99久久在免费线 | 亚洲色图视频网| 精品区一区二区| 欧美色精品天天在线观看视频| 懂色一区二区三区免费观看| 久久精品国产一区二区| 亚洲综合免费观看高清完整版在线| 一本色道久久综合狠狠躁的推荐 | 51午夜精品国产| 在线看国产一区| 国产999精品久久久久久| 婷婷夜色潮精品综合在线| **欧美大码日韩| 欧美国产一区二区在线观看| 日韩女优视频免费观看| 91精品国产综合久久国产大片| 色婷婷综合激情| 91小视频免费看| 成人h动漫精品一区二| 国产精品一区三区| 国产精品456| 国产中文字幕一区| 久久99精品久久久久| 免费看欧美美女黄的网站| 午夜视频在线观看一区| 亚洲小少妇裸体bbw| 亚洲一区二区三区视频在线播放| 亚洲色图色小说| 又紧又大又爽精品一区二区| 亚洲欧美偷拍另类a∨色屁股| 国产精品午夜电影| 国产精品美女久久久久aⅴ| 国产日韩欧美精品综合| 欧美国产一区在线| 亚洲欧洲日韩一区二区三区| 亚洲男人的天堂在线aⅴ视频| 亚洲理论在线观看| 亚洲一区视频在线观看视频| 欧美精品一二三| 亚洲欧洲精品一区二区三区不卡| 欧美日产国产精品| 欧美区在线观看| 日韩欧美综合一区| 精品国产成人在线影院| 国产亚洲精品精华液| 国产精品久久久久aaaa樱花 | 成人丝袜18视频在线观看| 国产成人aaa| 色狠狠色噜噜噜综合网| 欧美色图片你懂的| 精品国产乱码久久久久久夜甘婷婷 | 国产精品视频看| 一区二区三区在线免费视频| 午夜精品视频在线观看| 九九视频精品免费| 成人美女在线观看| 欧美三级一区二区| 欧美成人在线直播| 国产精品网站在线观看| 亚洲成年人网站在线观看| 裸体健美xxxx欧美裸体表演| 国产成人午夜精品5599| 97超碰欧美中文字幕| 欧美一级片在线| 国产精品少妇自拍| 五月天亚洲婷婷| 成人免费看黄yyy456| 欧美三区免费完整视频在线观看| 精品久久一二三区| 亚洲欧美日韩成人高清在线一区| 欧美aa在线视频| 99热在这里有精品免费| 欧美一区二区精美| 亚洲欧美激情插| 久久99久久久久久久久久久| 日本韩国一区二区三区| 精品国产免费一区二区三区香蕉| 亚洲免费观看高清| 国产精品一区二区三区四区| 欧美亚洲国产一区二区三区| 久久久电影一区二区三区| 亚洲一区二区偷拍精品| 高清不卡一区二区在线| 日韩三级视频在线看| 亚洲精品中文在线观看| 国产成人综合精品三级| 4438成人网| 香蕉久久夜色精品国产使用方法| 白白色亚洲国产精品| www成人在线观看| 五月天久久比比资源色| 91原创在线视频| 日本一二三不卡| 国产在线日韩欧美| 欧美日韩1234| 亚洲不卡在线观看| 91蝌蚪国产九色| 亚洲欧洲韩国日本视频| 国产精品一区二区三区乱码| 日韩欧美中文一区二区| 一区二区三区欧美在线观看| 成人激情小说乱人伦| 国产婷婷色一区二区三区在线| 欧洲日韩一区二区三区| 国产视频911| 国产福利不卡视频| 国产午夜精品一区二区| 韩国视频一区二区| 久久色在线观看| 狠狠色综合日日| 久久久午夜精品| 岛国精品在线播放| 国产亚洲va综合人人澡精品| 国产一区二区成人久久免费影院| 欧美成人精品1314www| 精一区二区三区|