⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 database.java

📁 “JSP数据库项目案例导航”一书从第一章到第十一章各章实例的源程序文件以及数据库文件。 注意: 1. 本书中的案例提供的数据库环境不同
💻 JAVA
📖 第 1 页 / 共 5 页
字号:
/**********************************************************
Copyright (C),2003-10-12, Beijing  USTB.
All rights reserved.
Filename: Datebase.java
Author:    
Version 1.0
Date:2003-10-12
Description:此文件为数据库的基本操作处理类
Other:
Variable List:
1.Connection conn = null;//数据库连接对象

Function List:
//基本操作
1.public DataBase()//构造函数
2.public void getConnPool()//取得连接池
3.public void createConn(String url,String usr,String pwd)//生成Oracle SQLServer等的连接
4.public void createConn(String url)//生成Access连接
5.public void releaseConn()//释放数据库连接
6.public ResultSet QuerySQL(String sql)//查询记录
7.public int ExecuteSQL(String sql)//执行增删改的语句

//辅助使用函数
8.public int makeID(String table,String field1,String field2,String value1,boolean type1)//产生唯一编号,type1为false时表示条件字段为字符串类型
  public int makeID(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)
  public int makeID_Add1(String table,String field1,String field2,String value1,boolean type1)//产生唯一编号,type1为false时表示条件字段为字符串类型
  public int makeID_Add1(String table,String field1,String field2,String field3,String value1,String value2,boolean type1,boolean type2)
9.public int toID(String table,String field1,String field2,String value1)//将名称转换为编号

10.public String toName(String table,String field1,String field2,String value)//将编号转换为名称
11.public Vector getOnePage(String sql,int page,int records)//分页时取得一页的数据量
12.public int setSort(String table,String field1,String field2,String wherestr,String orderstr,boolean b)//为某一个字段进行重新排序

//查询与更新LOB类型
13.public String QueryCLOB(String table,String wherestr,String clobfield)//查询CLOB类型值
14.public int UpdateCLOB(String table,String wherestr,String blobfield,String blobvalue)//修改CLOB类型值
15.public String QueryBLOB(String table,String wherestr,String blobfield)//查询BLOB类型值
16.public int UpdateBLOB(String table,String wherestr,String blobfield,String blobvalue)//修改BLOB类型值
17.public String QueryBLOB_JNDI(String table,String wherestr,String blobfield)//查询BLOB类型值
178.public int UpdateBLOB_JNDI(String table,String wherestr,String blobfield,String blobvalue)//修改BLOB类型值


//LOB类型基本操作(到文件)
19.public int clobInsert(String sql,String table,String wherestr,String clobfield,String infile)//往数据库中插入一个新的CLOB对象
20.public int clobModify(String table,String wherestr,String clobfield,String infile)//修改CLOB对象(是在原CLOB对象基础上进行覆盖式的修改)
21.public int clobReplace(String table,String wherestr,String clobfield,String infile)//替换CLOB对象(将原CLOB对象清除,换成一个全新的CLOB对象)
22.public int blobInsert(String sql,String table,String wherestr,String blobfield,String infile)//往数据库中插入一个新的BLOB对象
23.public int blobModify(String table,String wherestr,String blobfield,String infile)//修改BLOB对象(是在原BLOB对象基础上进行覆盖式的修改)
24.public int blobReplace(String table,String wherestr,String blobfield,String infile)//替换BLOB对象(将原BLOB对象清除,换成一个全新的BLOB对象)

//数据库结构信息
25.public Hashtable getDataBaseInfo()//数据库信息
26;public Vector getTableList()//数据表列表
27.public Vector getTableStruct(String table)//数据表的结构
28.public Vector getResultSetData(ResultSet rs)//取得数据集内容



41.public Vector getData(String sql);


//改动:三个关闭函数,一定要按照顺序关闭:conn,pstm,rs
11.public Vector getOnePage(String sql,int page,int records)//分页时取得一页的数据量
以下是经过分析后较好的两种ORACLE翻页SQL语句( ID是唯一关键字的字段名 ):
语句一:
SELECT ID, [FIELD_NAME,...] FROM TABLE_NAME WHERE ID IN ( SELECT ID FROM (SELECT ROWNUM AS NUMROW, ID FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3; 
语句二:
SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (select [FIELD_NAME,...] FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) c) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3;
例如:
SELECT * FROM (SELECT ROWNUM AS NUMROW, c.* from (select * FROM sms) c)
WHERE NUMROW > 80 AND NUMROW < 100 ;

///////////////////事务处理:在执行前设为非自动,完成后自动提交,这样效率更高/////////////////////////////////
//																									//
//		1.public boolean getAutoCommit();															//
//		2.public void closeAutoCommit();															//
//		3.public void commit();																		//
//		4.public void rollback();																	//
//		5.public void openAutoCommit();																//
//																									//
//////////////////////////////////////////////////////////////////////////////////////////////////////



////////////////////////////对sql语句的参数化处理(按如下顺序使用)////////////////////////////////////////
//																									//
//		1.public void prepareStatement(String sql)//创建申明对象										//
//		2.public void executeQuery()//执行查询														//
//		3.public boolean next()//转向下一条															//
//		4.public String getObject(String field,String sqlType)//取得数据并根据数据类型转化为字符串		//
//		5.public void setObject(int index,String value,String sqlType)//根据数据类型保存到数据库		//
//		6.public void executeUpdate()//执行更新														//
//		7.public void closePstm()//关闭申明对象														//
//		8.public void closeRs()//关闭游标																//
//																									//
//////////////////////////////////////////////////////////////////////////////////////////////////////



////////////////////////////对sql语句的批处理(按如下顺序使用)////////////////////////////////////////////
//参考SmaBean.add()																					//
//		0.Statement stm = null ;//专门使用															//
//		1.public void createStatement();//专门使用													//
//		2.public void clearBatch();																	//
//		3.public void addBatch(String sql);															//
//		4.public int[] executeBatch();																//
//		0.public void closeStm();//专门使用															//
//																									//
//////////////////////////////////////////////////////////////////////////////////////////////////////



History:
date:2003-11-21
name:liumei
action:修改getOnePage(String sql,int page,int records)//分页时取得一页的数据量
	   每页的记录显示条数从字典中取,即去掉records的作用
***********************************************************/
package oa.main;

import java.util.*;
import java.text.*;
import java.sql.*;
import java.io.*;
import java.lang.*;
import javax.naming.*;
import oracle.jdbc.driver.OracleResultSet;
import oracle.sql.*;

/**
 * 此文件为数据库的基本操作处理类
 * @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 static 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"); 
			//////////////////////tmaxtest////////////////////////////////////////////////////////
		//	Context initCtx = new InitialContext();
		//	javax.sql.DataSource ds = (javax.sql.DataSource)initCtx.lookup("jdbc/OracleDB");
      //////////////////////tmaxtest////////////////////////////////////////////////////////
			/**类型转换*/
			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
		{

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -