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

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

?? database.java

?? 新聞發布系統
?? JAVA
?? 第 1 頁 / 共 4 頁
字號:

package oa.main;

import java.util.*;
import java.text.*;
import java.sql.*;
import java.io.*;
import java.lang.*;
import javax.naming.*;


/**
 * 此文件為數據庫的基本操作處理類
 * @author 劉中兵
 * @version 1.0-hg
*/
public class DataBase extends Object
{
	Connection conn = null;
	Statement stm = null;
	PreparedStatement pstm = null;
	ResultSet rs = null;

	boolean connected = false;

	/**構造函數*/
	public DataBase()
	{
	}

	public void showConnNUM()
	{
		//連接池中使用
		DealString ds = new DealString();
		int curnum = Configuration.connMgr.getCurConns(Configuration.ConnectionPoolName);
		int sumnum = Configuration.connMgr.getSumConns(Configuration.ConnectionPoolName);
		int maxnum = Configuration.connMgr.getMaxConns(Configuration.ConnectionPoolName);
		int isNullPool = Configuration.connMgr.getNullPool(Configuration.ConnectionPoolName);
		int isOracleErr = Configuration.connMgr.getOracleErr(Configuration.ConnectionPoolName);
		int jvmcount = ParentBean.count;
		float jvm1 = (float)Runtime.getRuntime().totalMemory()/1024/1024;
		float jvm2 = (float)Runtime.getRuntime().maxMemory()/1024/1024;
		System.out.print("\r" + ds.getDateTime ( ).substring ( 11 , 19 ) + "  連接累計> "+ds.toLengthStrRight(sumnum+"",10)+"當前連接> "+ds.toLengthStrRight(curnum+"",10)+"池中連接> "+ds.toLengthStrRight(maxnum+"",10)+"池空未連接> " +ds.toLengthStrRight(isNullPool+"",10)+"DB未響應> " +ds.toLengthStrRight(isOracleErr+"",10)+"JVM垃圾回收> "+jvmcount+"  ");
	}

	/**取得連接池*/
	public void getConnPool()
	{
		try
		{
			if(connected){
				throw new SQLException("數據庫已連接,無須重連!");
			}
			Context initCtx = new InitialContext(); 
			Context ctx = (Context) initCtx.lookup("java:comp/env"); 

			/**獲取連接池對象*/
			Object obj = (Object) ctx.lookup("jdbc/OracleDB"); 

			/**類型轉換*/
			javax.sql.DataSource ds = (javax.sql.DataSource)obj; 
			conn = ds.getConnection();

			/**測試連接計數*/
			connected = true;
			showConnNUM();
		}
		catch(NamingException e){System.out.println("從數據池取得數據庫連接時出錯;\r\n錯誤為:"+e);}
		catch(SQLException e){System.out.println("從數據池取得數據庫連接時出錯;\r\n錯誤為:"+e);}
	}

	/**創建我的連接池*/
	public boolean getMyConnPool()
	{
		conn = Configuration.connMgr.getConnection(Configuration.ConnectionPoolName);
		showConnNUM();
		if(conn == null)
		{
			return false;
		}
		else
		{
			return true;
		}
	}

	/**釋放我的連接池*/
	public boolean releaseMyConnPool()
	{
		boolean b;
		if ( conn !=null )
		{
			b = true;
		}
		else
		{
			b = false;
		}
		Configuration.connMgr.freeConnection(Configuration.ConnectionPoolName, conn);
		conn = null ;
		showConnNUM();
		return b;
	}

/*
	public void getConnDataSourse()
	{
		try
		{

			OracleDataSource ods = new OracleDataSource();
			ods.setDriverType("thin");
			ods.setServerName("10.0.0.94");
			ods.setNetworkProtocol("tcp");
			ods.setDatabaseName("hg");
			ods.setPortNumber(1521);
			ods.setUser("oaadminuser");
			ods.setPassword("lancom4454");

			// 從數據源中獲取數據庫連接
			conn = ods.getConnection();

			/**測試連接計數
			ParentBean.curnum++;
			ParentBean.sumnum++;
		}
		catch(SQLException e){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+e);}
	}

	public void getConnJNDI()
	{
		Context ctx = null;
		try
		{
			//建立上下文環境
			Hashtable env = new Hashtable (5);
			env.put (Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.fscontext.RefFSContextFactory");
			env.put (Context.PROVIDER_URL, "file:JNDI");
			ctx = new InitialContext(env);

			//從JNDI取得連接
			OracleDataSource ods1 = (OracleDataSource) ctx.lookup ("jdbc/chidb");

			if(ods1==null)
			{
				

				//建立數據源綁定
				OracleDataSource ods = new OracleDataSource();
				ods.setDriverType("thin");
				ods.setServerName("10.0.0.94");
				ods.setNetworkProtocol("tcp");
				ods.setDatabaseName("hg");
				ods.setPortNumber(1521);
				ods.setUser("oaadminuser");
				ods.setPassword("lancom4454");
				ctx.bind ("jdbc/chidb",ods);
			}

			ods1 = (OracleDataSource) ctx.lookup ("jdbc/chidb");
			conn = ods1.getConnection();

		}
		catch(SQLException e){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+e);}
		catch (NamingException ne)
		{
			ne.printStackTrace();
		}
	}
*/

	/**生成Oracle SQLServer等的連接*/
	public void createConn(String drv,String url,String usr,String pwd)
	{
		try
		{
			if(connected){
				throw new SQLException("數據庫已連接,無須重連!");
			}
			Class.forName(drv).newInstance();
			conn = DriverManager.getConnection(url,usr,pwd);

			connected = true;

			/**測試連接計數*/
			showConnNUM();
		}
		catch(ClassNotFoundException ec){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+ec);}
		catch(SQLException e){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+e);}
		catch(Exception et){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+et);}
	}

	/**生成Access連接*/
	public void createConn(String drv,String url)
	{
		try
		{
			if(connected){
				throw new Exception("數據庫已連接,無須重連!");
			}
			Class.forName(drv).newInstance();
			conn = DriverManager.getConnection(url);
			connected = true;

			/**測試連接計數*/
			showConnNUM();
		}
		catch(ClassNotFoundException ec){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+ec);}
		catch(SQLException e){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+e);}
		catch(Exception et){System.out.println("從自身建立數據庫連接時出錯;\r\n錯誤為:"+et);}
	}

	/**釋放數據庫連接*/
	public void releaseConn()
	{
		try
		{
			if(!connected){
				//throw new SQLException("數據庫未連接!");
			}
			if(conn!=null)
			{
				conn.close();
				connected = false;

				/**測試連接計數*/
				showConnNUM();
			}
		}
		catch(SQLException e){System.out.println("關閉數據庫連接時出錯;\r\n錯誤為:"+e);}
	}	

	/**查詢記錄*/
	public ResultSet QuerySQL(String sql)
	{
		ResultSet rs = null;
		try
		{
			pstm = conn.prepareStatement(sql);
			rs = pstm.executeQuery();
		}catch(SQLException sqle){
			System.out.println("執行DataBase::QuerySQL(String)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);
			if(pstm!=null)
			try{pstm.close();}catch(Exception e){System.out.println("執行DataBase::QuerySQL(String)試圖關閉錯誤的聲明時出錯;\r\n錯誤為:"+e);}
		}
		return rs;
	}

	/**執行增刪改的語句*/
	public int ExecuteSQL(String sql)
	{
		try
		{
			pstm = conn.prepareStatement(sql);
			pstm.executeUpdate();
			conn.commit();
		}
		catch(SQLException sqle)
		{
			//System.out.println("執行DataBase::ExecuteSQL(String)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);
			return sqle.getErrorCode();
		}
		finally{
			try{
			pstm.close();
			}catch(SQLException sqle){System.out.println("執行DataBase::ExecuteSQL(String)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);}
		}
		return 0;
	}

	/**產生唯一編號*/
 	public int makeID(String table,String field1,String field2,String value1,boolean type1)
	{
		int out = -1;
		String sql = "";
		try
		{
					//只有唯一主鍵field1
			sql = "select "+field1+" as ID from "+table+" order by "+field1;
					//有兩個主鍵field1、field2
			if(!value1.equals(""))//當第一個字段不空時,作為條件查詢第二個字段
			{
				sql = "select "+field2+" as ID from "+table+" where "+field1+"="+value1+" order by "+field2;
				if(!type1)       //是字符串時 將type1設為false
					sql = "select "+field2+" as ID from "+table+" where "+field1+"='"+value1+"' order by "+field2;
			}
			pstm = conn.prepareStatement(sql);
			rs = pstm.executeQuery();
			int t1 = 1;
			int t2 = 2;
			if(rs.next())  //有記錄
			{
				t1 = rs.getInt("ID");
				out = t1;
				boolean bool = false;
				while(rs.next())   //不止一條紀錄
				{
					bool = true;
					t2 = rs.getInt("ID");
					if((t2-t1)>1)break;  //如果t2與t1相差大于1,則跳出去,新編號為t1++(見后面**)
					t1 = t2;			//否則將t2賦給t1
				}
				if(!bool)  //如果只有一條紀錄
				{
					if(t1>1)t1 = 1;  //如果已有紀錄的ID號大于1,則新編號設為1
					else t1++;
				}
				else t1++;		//**
			}
			if(out>1)out = 1;
			else out = t1;

		}catch(SQLException sqle){System.out.println("執行DataBase::makeID(String table,String field1,String field2,String value1,boolean type1)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);}
		finally{
			if(rs!=null){
				try{
				rs.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID(String table,String field1,String field2,String value1,boolean type1)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
			if(pstm!=null){
				try{
				pstm.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID(String table,String field1,String field2,String value1,boolean type1)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
		}
		return out;
	}

	/**產生唯一編號*/
 	public int makeID_Add1(String table,String field1,String field2,String value1,boolean type1)
	{
		int out = -1;
		String sql = "";
		try
		{
					//只有唯一主鍵field1
			sql = "select max("+field1+")+1 as ID from "+table+" order by "+field1;
					//有兩個主鍵field1、field2
			if(!value1.equals(""))//當第一個字段不空時,作為條件查詢第二個字段
			{
				sql = "select ("+field2+")+1 as ID from "+table+" where "+field1+"="+value1+" order by "+field2;
				if(!type1)       //是字符串時 將type1設為false
					sql = "select ("+field2+")+1 as ID from "+table+" where "+field1+"='"+value1+"' order by "+field2;
			}
			pstm = conn.prepareStatement(sql);
			rs = pstm.executeQuery();
			if(rs.next())  //有記錄
			{
				out = rs.getInt(1);
			}
		}catch(SQLException sqle){System.out.println("執行DataBase::makeID_Add1(String table,String field1,String field2,String value1,boolean type1)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);}
		finally{
			if(rs!=null){
				try{
				rs.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID_Add1(String table,String field1,String field2,String value1,boolean type1)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
			if(pstm!=null){
				try{
				pstm.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID_Add1(String table,String field1,String field2,String value1,boolean type1)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
		}
		return out;
	}

 	public int makeID(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)
	{
		int out = -1;
		String sql = "";
		try
		{
					//只有唯一主鍵field1
			sql = "select "+field1+" as ID from "+table+" order by "+field1;
					//有兩個主鍵field1、field2
			if(!value1.equals(""))//當第一個字段不空時,作為條件查詢第二個字段
			{
				sql = "select "+field2+" as ID from "+table+" where "+field1+"="+value1+" order by "+field2;
				if(!type1)       //是字符串時 將type1設為false
					sql = "select "+field2+" as ID from "+table+" where "+field1+"='"+value1+"' order by "+field2;
			}
			if(!value2.equals(""))//當第二個字段不空時,作為條件查詢第三個字段
			{
				sql = "select "+field3+" as ID from "+table+" where "+field1+"="+value1+" and "+field2+"="+value2+" order by "+field3;
				if(!type2)       //是字符串時 將type1設為false
					sql = "select "+field3+" as ID from "+table+" where "+field1+"='"+value1+"' and "+field2+"='"+value2+"' order by "+field3;
			}
			pstm = conn.prepareStatement(sql);
			rs = pstm.executeQuery();
			int t1 = 1;
			int t2 = 2;
			if(rs.next())  //有記錄
			{
				t1 = rs.getInt("ID");
				out = t1;
				boolean bool = false;
				while(rs.next())   //不止一條紀錄
				{
					bool = true;
					t2 = rs.getInt("ID");
					if((t2-t1)>1)break;  //如果t2與t1相差大于1,則跳出去,新編號為t1++(見后面**)
					t1 = t2;			//否則將t2賦給t1
				}
				if(!bool)  //如果只有一條紀錄
				{
					if(t1>1)t1 = 1;  //如果已有紀錄的ID號大于1,則新編號設為1
					else t1++;
				}
				else t1++;		//**
			}
			if(out>1)out = 1;
			else out = t1;
		}catch(SQLException sqle){System.out.println("執行DataBase::makeID(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);}
		finally{
			if(rs!=null){
				try{
				rs.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
			if(pstm!=null){
				try{
				pstm.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
		}
		return out;
	}

	public int makeID_Add1(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)
	{
		int out = -1;
		String sql = "";
		try
		{
					//只有唯一主鍵field1
			sql = "select max("+field1+") as ID from "+table+" order by "+field1;
					//有兩個主鍵field1、field2
			if(!value1.equals(""))//當第一個字段不空時,作為條件查詢第二個字段
			{
				sql = "select max("+field2+") as ID from "+table+" where "+field1+"="+value1+" order by "+field2;
				if(!type1)       //是字符串時 將type1設為false
					sql = "select max("+field2+") as ID from "+table+" where "+field1+"='"+value1+"' order by "+field2;
			}
			if(!value2.equals(""))//當第二個字段不空時,作為條件查詢第三個字段
			{
				sql = "select max("+field3+") as ID from "+table+" where "+field1+"="+value1+" and "+field2+"="+value2+" order by "+field3;
				if(!type2)       //是字符串時 將type1設為false
					sql = "select max("+field3+") as ID from "+table+" where "+field1+"='"+value1+"' and "+field2+"='"+value2+"' order by "+field3;
			}
			pstm = conn.prepareStatement(sql);
			rs = pstm.executeQuery();
			if(rs.next())  //有記錄
			{
				out = rs.getInt("ID");
			}
		}catch(SQLException sqle){System.out.println("執行DataBase::makeID_Add1(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+sqle);}
		finally{
			if(rs!=null){
				try{
				rs.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID_Add1(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}
			}
			if(pstm!=null){
				try{
				pstm.close();
				}catch(SQLException e){System.out.println("執行DataBase::makeID_Add1(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)調用SQL語句 "+sql+" 時出錯;\r\n錯誤為:"+e);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产全国免费观看| 暴力调教一区二区三区| 99久久伊人精品| 欧美一区二区三区日韩| 亚洲欧美另类图片小说| 国产黄色精品视频| 91精品婷婷国产综合久久竹菊| 久久久久久久久久美女| 免费观看一级特黄欧美大片| 91啪亚洲精品| 国产精品丝袜91| 国产在线一区二区| 制服丝袜中文字幕一区| 亚洲一级二级三级| 99久久99久久综合| 久久精品在这里| 美女视频网站久久| 制服丝袜国产精品| 夜夜揉揉日日人人青青一国产精品| 国产成人在线观看| 精品电影一区二区| 裸体健美xxxx欧美裸体表演| 欧美色男人天堂| 亚洲免费av网站| 国产黄人亚洲片| 久久伊人中文字幕| 久久99热这里只有精品| 91精品国产入口| 日韩va亚洲va欧美va久久| 欧美日韩国产欧美日美国产精品| 亚洲欧洲中文日韩久久av乱码| 国产成人免费9x9x人网站视频| 日韩欧美国产午夜精品| 青青草精品视频| 8x福利精品第一导航| 视频一区在线播放| 欧美日韩三级一区| 五月婷婷激情综合网| 欧美日韩一级视频| 天堂av在线一区| 欧美精品第1页| 奇米888四色在线精品| 7777精品伊人久久久大香线蕉 | 国产精品日产欧美久久久久| 国产一区二区91| 精品少妇一区二区| 久久国产精品99精品国产 | 国产日韩影视精品| 国产精品123区| 国产三级欧美三级日产三级99| 国内精品嫩模私拍在线| 久久综合久久99| 国产精品456露脸| 国产精品天美传媒| 成人免费观看av| 亚洲图片欧美激情| 欧洲一区二区三区在线| 亚洲va欧美va人人爽午夜| 91精品国产91热久久久做人人| 久久精品国产秦先生| 久久精品这里都是精品| 99久久国产综合精品麻豆| 亚洲最大成人综合| 欧美日本一区二区三区| 麻豆一区二区三区| 国产欧美精品在线观看| eeuss鲁片一区二区三区| 一级中文字幕一区二区| 91精品国模一区二区三区| 久久99精品久久久| 日本一区二区成人| 在线亚洲高清视频| 久久爱另类一区二区小说| 欧美激情一区二区三区不卡 | 免费人成精品欧美精品| 2021中文字幕一区亚洲| av男人天堂一区| 亚洲v日本v欧美v久久精品| 日韩欧美亚洲国产精品字幕久久久| 国产精品综合一区二区三区| 亚洲欧洲99久久| 欧美妇女性影城| 国产成人8x视频一区二区| 一区二区三区免费| 精品国产亚洲一区二区三区在线观看| 国产成人a级片| 亚洲国产美女搞黄色| 国产亚洲污的网站| 精品视频一区三区九区| 国产大陆a不卡| 一区二区三区四区亚洲| 日韩精品一区二区三区中文精品| 成人午夜视频网站| 婷婷国产v国产偷v亚洲高清| 国产视频视频一区| 欧美性猛片aaaaaaa做受| 日本中文一区二区三区| 国产精品麻豆视频| 欧美一区二区网站| av欧美精品.com| 精品一区二区在线免费观看| 亚洲欧美成人一区二区三区| 精品久久久久久久久久久久久久久久久 | 91.成人天堂一区| 成人动漫在线一区| 日本女人一区二区三区| 亚洲免费av在线| 国产喷白浆一区二区三区| 欧美日韩精品系列| 成人黄色电影在线| 久久精工是国产品牌吗| 一区二区三区在线视频观看58| 亚洲精品一区二区三区在线观看| 91精品1区2区| 国产成人综合网站| 麻豆精品精品国产自在97香蕉| 亚洲精品中文在线| 欧美激情一区二区三区全黄| 91精品国产91久久综合桃花| 91麻豆自制传媒国产之光| 国产精品中文有码| 日韩国产欧美在线观看| 亚洲视频 欧洲视频| 欧美mv日韩mv| 欧美精品乱码久久久久久| 99精品桃花视频在线观看| 精品中文字幕一区二区| 午夜久久电影网| 亚洲色欲色欲www在线观看| 久久精品免视看| 欧美电视剧免费观看| 91麻豆精品国产自产在线| 欧美在线观看视频一区二区| 成人av电影免费在线播放| 国产一级精品在线| 麻豆精品一区二区综合av| 午夜精品视频在线观看| 亚洲女爱视频在线| 国产精品福利影院| 欧美国产综合色视频| 久久影音资源网| 久久夜色精品一区| 欧美videos中文字幕| 91精品国产综合久久蜜臀| 欧美色视频在线| 懂色av一区二区三区蜜臀| 亚洲男人天堂av网| 国产精品久久久久久久裸模| 久久女同精品一区二区| 精品国产a毛片| 日韩精品一区二区三区在线 | 国产成人啪免费观看软件| 狠狠久久亚洲欧美| 精品无人区卡一卡二卡三乱码免费卡| 蜜桃在线一区二区三区| 免费观看在线色综合| 青青草97国产精品免费观看| 日本不卡一区二区三区| 视频一区中文字幕| 琪琪一区二区三区| 九九精品视频在线看| 激情综合一区二区三区| 国产一区二区在线观看视频| 国产综合色视频| 国产美女娇喘av呻吟久久| 国产高清久久久| av一本久道久久综合久久鬼色| 成人精品视频一区二区三区尤物| 福利电影一区二区三区| 不卡电影一区二区三区| 99国产精品视频免费观看| 91蝌蚪国产九色| 欧美午夜精品免费| 91精品国产综合久久香蕉的特点| 日韩精品一区二区三区在线播放 | 欧美日韩一区成人| 日韩一区二区在线观看| 欧美tickle裸体挠脚心vk| 久久众筹精品私拍模特| 国产精品素人视频| 一区二区三区免费看视频| 天堂va蜜桃一区二区三区漫画版| 蜜桃传媒麻豆第一区在线观看| 美美哒免费高清在线观看视频一区二区| 毛片av一区二区| 岛国av在线一区| 色综合婷婷久久| 欧美精选午夜久久久乱码6080| 欧美一区二区免费视频| 久久久国产午夜精品| 亚洲蜜臀av乱码久久精品| 日本欧美在线看| 国产成人免费视频网站| 欧美在线你懂得| 精品久久久久久最新网址| 国产精品理伦片| 亚洲电影一级黄| 韩国三级中文字幕hd久久精品| 成人精品一区二区三区四区| 欧美日韩国产免费|