//数据库连接池 单例模式
import javasqlConnection;
import javasqlSQLException;
import commchangev2c3p0ComboPooledDataSource;
import commchangev2c3p0DataSources;
public final class ConnectionManager {
private static ConnectionManager instance;
private ComboPooledDataSource ds;
private ConnectionManager() throws Exception {
ds = new ComboPooledDataSource();
dssetDriverClass("oraclejdbcdriverOracleDriver");
dssetJdbcUrl("jdbc:oracle:thin:@127001:1521:orcl");
dssetUser("test");
dssetPassword("testtest");
//初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 initialPoolSize
dssetInitialPoolSize(3);
//连接池中保留的最大连接数。Default: 15 maxPoolSize
dssetMaxPoolSize(10);
//// 连接池中保留的最小连接数。
//dssetMinPoolSize(1);
//当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 acquireIncrement
dssetAcquireIncrement(1);
//每60秒检查所有连接池中的空闲连接。Default: 0 idleConnectionTestPeriod
dssetIdleConnectionTestPeriod(60);
//最大空闲时间,25000秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 maxIdleTime
dssetMaxIdleTime(25000);
//连接关闭时默认将所有未提交的 *** 作回滚。Default: false autoCommitOnClose
dssetAutoCommitOnClose(true);
//定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:
//测试的表必须在初始数据源的时候就存在。Default: null preferredTestQuery
dssetPreferredTestQuery("select sysdate from dual");
// 因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的
// 时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable
// 等方法来提升连接测试的性能。Default: false testConnectionOnCheckout
dssetTestConnectionOnCheckout(true);
//如果设为true那么在取得连接的同时将校验连接的有效性。Default: false testConnectionOnCheckin
dssetTestConnectionOnCheckin(true);
//定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 acquireRetryAttempts
dssetAcquireRetryAttempts(30);
//两次连接中间隔时间,单位毫秒。Default: 1000 acquireRetryDelay
dssetAcquireRetryDelay(1000);
//获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效
//保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试
//获取连接失败后该数据源将申明已断开并永久关闭。Default: false breakAfterAcquireFailure
dssetBreakAfterAcquireFailure(true);
// <!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出
// SQLException,如设为0则无限期等待。单位毫秒。Default: 0 -->
// <property name="checkoutTimeout">100</property>
// <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么
// 属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何 *** 作,它将只供c3p0测试
// 使用。Default: null-->
// <property name="automaticTestTable">Test</property>
// <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements
// 属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。
// 如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
// <property name="maxStatements">100</property>
// <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
// <property name="maxStatementsPerConnection"></property>
// <!--c3p0是异步 *** 作的,缓慢的JDBC *** 作通过帮助进程完成。扩展这些 *** 作可以有效的提升性能
// 通过多线程实现多个 *** 作同时被执行。Default: 3-->
// <property name="numHelperThreads">3</property>
// <!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->
// <property name="propertyCycle">300</property>
}
public static final ConnectionManager getInstance() {
if (instance == null) {
try {
instance = new ConnectionManager();
} catch (Exception e) {
eprintStackTrace();
}
}
return instance;
}
public synchronized final Connection getConnection() {
try {
return dsgetConnection();
} catch (SQLException e) {
eprintStackTrace();
}
return null;
}
protected void finalize() throws Throwable {
DataSourcesdestroy(ds); //关闭datasource
superfinalize();
}
}
//调用数据库连接池
import javasqlConnection;
import javasqlResultSet;
import javasqlStatement;
public class TestC3p0 {
public TestC3p0() {
// TODO 自动生成构造函数存根
}
public static void main(String[] args) {
// TODO 自动生成方法存根
ConnectionManager cm = ConnectionManagergetInstance();
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
String sql = "select sysdate from dual";
for (int i = 0; i < 10000; i++) {
try {
conn = cmgetConnection();
Systemoutprintln(conn);
stmt = conncreateStatement();
rs = stmtexecuteQuery(sql);
rsnext();
Systemoutprintln(rsgetString(1));
} catch (Exception ex) {
exprintStackTrace();
} finally {
if (rs != null) {
try {
rsclose();
} catch (Exception e) {
}
}
if (stmt != null) {
try {
stmtclose();
} catch (Exception e) {
}
}
if (conn != null) {
try {
connclose();
} catch (Exception e) {
}
}
}
try {
Systemoutprintln(cmdstoString());
Threadsleep(10000);
} catch (Exception e) {
// TODO: handle exception
}
}
}
}
ORACLE数据库中文排序规则
oracle9i之前,中文是按照二进制编码进行排序的。
在oracle9i中新增了按照拼音、部首、笔画排序功能。设置NLS_SORT值
SCHINESE_RADICAL_M 按照部首(第一顺序)、笔划(第二顺序)排序
SCHINESE_STROKE_M 按照笔划(第一顺序)、部首(第二顺序)排序
SCHINESE_PINYIN_M 按照拼音排序,系统的默认排序方式为拼音排序
alter session set nls_sort=’schinese_pinyin_m’;
select from dept order by nlssort(name,’NLS_SORT=SCHINESE_PINYIN_M’);
Oracle数据库内核是用C编写的。但是,大部分代码在数据库内部执行,并且使用PL / SQL和Java(使用嵌入在内核中的JVM)进行开发。外围工具(SQL Developer,网格控件)主要使用Java。
MySQL用C和C ++编写。它的SQL解析器是用yacc编写的,但它使用的是自制的词法分析器。MySQL可在许多系统平台上工作。
扩展资料:
Oracle的文件结构:
数据库的物理存储结构是由一些多种物理文件组成,主要有数据文件、控制文件、重做日志文件、归档日志文件、参数文件、口令文件、警告文件等。
1、控制文件:存储实例、数据文件及日志文件等信息的二进制文件。alter system set control_files=‘路径’。V$CONTROLFILE。
2、数据文件:存储数据,以dbf做后缀。一句话:一个表空间对多个数据文件,一个数据文件只对一个表空间。dba_data_files/v$datafile。
3、日志文件:即Redo Log Files和Archivelog Files。记录数据库修改信息。ALTER SYSTEM SWITCH LOGFILE; 。V$LOG。
4、参数文件:记录基本参数。spfile和pfile。
5、警告文件:show parameter background_dump_dest---使用共享服务器连接。
6、跟踪文件:show parameter user_dump_dest---使用专用服务器连接 。
1、Web 其实写B/S也可以的
2、主机地址(填ip地址也可以)和端口号
2、i代表Internet,g代表grid,也就是网格计算的意思
3、概念问题,不好说了
4、控制文件、数据文件
5、表空间、数据库(没听说过其他的层次,Oracle官方的教材也只讲数据库、表空间、段、区、块这五层)
6、数据库对象
7、desc、select
8、>
以上就是关于求大神!用Oracle完成一个数据库应用系统的设计全过程全部的内容,包括:求大神!用Oracle完成一个数据库应用系统的设计全过程、oracle数据库中文怎么排序规则、请问mysql和Oracle分别用什么语言写的啊等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)