求大神!用Oracle完成一个数据库应用系统的设计全过程

求大神!用Oracle完成一个数据库应用系统的设计全过程,第1张

//数据库连接池 单例模式

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分别用什么语言写的啊等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9746557.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存