咿哑的读音:提高ORACLE数据库的查询统计速度
来源:百度文库 编辑:中财网 时间:2024/05/10 08:54:32
作者:郁郁小蝎 来源:中国站长学院 发布时间:2005-4-3 14:59:59 发布人:admin
增大字体
大型数据库系统中往往要用到查询统计,但是对于数据量大的系统,用户在进行复杂的查询统计时往往感到速度很慢,不能满足应用要求,这就要求我们在设计数据库系统时进行合理设置,提高查询统计的速度。本文结合笔者的项目开发经验,阐述具体的设置方法。
以oracle7.33数据库系统为例,我们在开发大型oracle数据库系统时结合项目的特点,本着安全、高效的原则对数据库进行了一些物理设计,从而大大提高了数据库的查询统计速度。总结为如下几点:
1)扩大数据表空间到500M,用于存放本系统的数据;
2)段盘区的初始大小为10K,增长大小为10K,增长幅度为1;
3)用户临时空间增大40M;
4)系统临时表空间和回滚段表空间增大40M,并且新建4个回滚段;
5)需要经常联结查询,而且数据量又大的库存表、名录表、收发料表放在一簇内;
6)提供定时备份,备份文件放在另外的机器上。
设置数据表空间的SQL语句如下:
CREATE TABLESPACE WXGL_DATA1 DATAFILE ‘WXGL_DATA1.ORA‘ SIZE 500M ONLINE;
增加系统临时表空间和回滚段表空间的SQL语句如下:
ALTER TABLESPACE TEMPORARY_DATA ADD DATAFILE ‘TMP2ORCL.ORA‘ SIZE 40M;
ALTER TABLESPACE ROLLBACK_DATA ADD DATAFILE ‘RBS2ORCL.ORA‘ SIZE 40M;
将数据空间设置在指定的数据文件的SQL语句如下:
CREATE USER ZBGL IDENTIFIED BY ZBGL;
GRANT DBA TO ZBGL;
ALTER USER ZBGL DEFAULT TABLESPACE WXGL_DATA1 TEMPORARY TABLESPACE TEMPORARY_DATA; 1. 设置五个回滚段的SQL语句如下:
SELECT SEGMENT_NAME FROM DBA_ROLLBACK_SEGS WHERE INITIAL_EXTENT < 512000 AND
UPPPER(OWNER) = ‘PUBLIC‘;
SELECT UPPER(STATUS) FROM DBA_ROLLBACK_SEGS WHERE UPPER(SEGMENT_NAME) = ‘‘
ALTER ROLLBACK SEGMENT RB1 OFFLINE;
ALTER ROLLBACK SEGMENT RB2 OFFLINE;
ALTER ROLLBACK SEGMENT RB3 OFFLINE;
ALTER ROLLBACK SEGMENT RB4 OFFLINE;
ALTER ROLLBACK SEGMENT RB5 OFFLINE;
DROP ROLLBACK SEGMENT RB1;
DROP ROLLBACK SEGMENT RB2;
DROP ROLLBACK SEGMENT RB3;
DROP ROLLBACK SEGMENT RB4;
DROP ROLLBACK SEGMENT RB5;
CREATE PUBLIC ROLLBACK SEGMENT RB1 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB2 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB3 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB4 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB5 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
ALTER ROLLBACK SEGMENT RB1 ONLINE;
ALTER ROLLBACK SEGMENT RB2 ONLINE;
ALTER ROLLBACK SEGMENT RB3 ONLINE;
ALTER ROLLBACK SEGMENT RB4 ONLINE;
ALTER ROLLBACK SEGMENT RB5 ONLINE;
COMMIT;
2.将数据量大的库存表等放在一簇内的SQL语句如下:
KCB=‘CREATE TABLE QC_KCB( ‘
+‘ CKNM NUMBER(8) ,‘
+‘ QCNM NUMBER(10) ,‘
+‘ CKKC NUMBER(12,2),‘
+‘ SNCKKC NUMBER(12,2),‘
+‘ LDJ NUMBER(12,2),‘
+‘ BZ VARCHAR(100),‘
+‘ PRIMARY KEY(CKNM,QCNM))‘
+‘ TABLESPACE WXGL_DATA1 ‘ ;(大数据量的库存表等放在WXGL_DATA1)
QCFL = ‘CREATE TABLE QC_QCFL ‘
+ ‘(FLBH NUMBER(2) PRIMARY KEY,‘
+ ‘ FLMC VARCHAR(20) ‘
+ ‘ ) ‘
+‘ TABLESPACE WXGL_DATA2 ‘ ;(其他表放在WXGL_DATA2
增大字体
大型数据库系统中往往要用到查询统计,但是对于数据量大的系统,用户在进行复杂的查询统计时往往感到速度很慢,不能满足应用要求,这就要求我们在设计数据库系统时进行合理设置,提高查询统计的速度。本文结合笔者的项目开发经验,阐述具体的设置方法。
以oracle7.33数据库系统为例,我们在开发大型oracle数据库系统时结合项目的特点,本着安全、高效的原则对数据库进行了一些物理设计,从而大大提高了数据库的查询统计速度。总结为如下几点:
1)扩大数据表空间到500M,用于存放本系统的数据;
2)段盘区的初始大小为10K,增长大小为10K,增长幅度为1;
3)用户临时空间增大40M;
4)系统临时表空间和回滚段表空间增大40M,并且新建4个回滚段;
5)需要经常联结查询,而且数据量又大的库存表、名录表、收发料表放在一簇内;
6)提供定时备份,备份文件放在另外的机器上。
设置数据表空间的SQL语句如下:
CREATE TABLESPACE WXGL_DATA1 DATAFILE ‘WXGL_DATA1.ORA‘ SIZE 500M ONLINE;
增加系统临时表空间和回滚段表空间的SQL语句如下:
ALTER TABLESPACE TEMPORARY_DATA ADD DATAFILE ‘TMP2ORCL.ORA‘ SIZE 40M;
ALTER TABLESPACE ROLLBACK_DATA ADD DATAFILE ‘RBS2ORCL.ORA‘ SIZE 40M;
将数据空间设置在指定的数据文件的SQL语句如下:
CREATE USER ZBGL IDENTIFIED BY ZBGL;
GRANT DBA TO ZBGL;
ALTER USER ZBGL DEFAULT TABLESPACE WXGL_DATA1 TEMPORARY TABLESPACE TEMPORARY_DATA; 1. 设置五个回滚段的SQL语句如下:
SELECT SEGMENT_NAME FROM DBA_ROLLBACK_SEGS WHERE INITIAL_EXTENT < 512000 AND
UPPPER(OWNER) = ‘PUBLIC‘;
SELECT UPPER(STATUS) FROM DBA_ROLLBACK_SEGS WHERE UPPER(SEGMENT_NAME) = ‘‘
ALTER ROLLBACK SEGMENT RB1 OFFLINE;
ALTER ROLLBACK SEGMENT RB2 OFFLINE;
ALTER ROLLBACK SEGMENT RB3 OFFLINE;
ALTER ROLLBACK SEGMENT RB4 OFFLINE;
ALTER ROLLBACK SEGMENT RB5 OFFLINE;
DROP ROLLBACK SEGMENT RB1;
DROP ROLLBACK SEGMENT RB2;
DROP ROLLBACK SEGMENT RB3;
DROP ROLLBACK SEGMENT RB4;
DROP ROLLBACK SEGMENT RB5;
CREATE PUBLIC ROLLBACK SEGMENT RB1 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB2 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB3 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB4 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
CREATE PUBLIC ROLLBACK SEGMENT RB5 TABLESPACE ROLLBACK_DATA
STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);
ALTER ROLLBACK SEGMENT RB1 ONLINE;
ALTER ROLLBACK SEGMENT RB2 ONLINE;
ALTER ROLLBACK SEGMENT RB3 ONLINE;
ALTER ROLLBACK SEGMENT RB4 ONLINE;
ALTER ROLLBACK SEGMENT RB5 ONLINE;
COMMIT;
2.将数据量大的库存表等放在一簇内的SQL语句如下:
KCB=‘CREATE TABLE QC_KCB( ‘
+‘ CKNM NUMBER(8) ,‘
+‘ QCNM NUMBER(10) ,‘
+‘ CKKC NUMBER(12,2),‘
+‘ SNCKKC NUMBER(12,2),‘
+‘ LDJ NUMBER(12,2),‘
+‘ BZ VARCHAR(100),‘
+‘ PRIMARY KEY(CKNM,QCNM))‘
+‘ TABLESPACE WXGL_DATA1 ‘ ;(大数据量的库存表等放在WXGL_DATA1)
QCFL = ‘CREATE TABLE QC_QCFL ‘
+ ‘(FLBH NUMBER(2) PRIMARY KEY,‘
+ ‘ FLMC VARCHAR(20) ‘
+ ‘ ) ‘
+‘ TABLESPACE WXGL_DATA2 ‘ ;(其他表放在WXGL_DATA2
怎么样设计数据库,可以提高查询速度?
一个关于数据库查询速度的问题
听说Cache数据库的速度是Oracle的十倍,有谁知道用过这个数据库?
怎样提高SQLSERVER的like查询速度?
(急急急!)如何利用sql语句在oracle数据库中查询一个时间段的内容!
连接oracle数据库的问题
数据库里面的oracle是什么意思
关于ORACLE数据库的书籍
access 数据库 求sql统计查询语句
sql 数据库与Oracle数据库的比较
oracle 打开数据库归档模式 对数据的运行速度及安全性能有影响吗?
关于数据库查询速度问题
sql查询,投票的数据库中如何统计票数并排名呢?
ORACLE查询
oracle数据库的表空间扩展问题
ORACLE数据库建表的问题
数据库Oracle的主要优势在那里?
关于创建Oracle数据库的内存问题
生成oracle数据库结构的工具
oracle数据库配置方面的问题
关于oracle数据库的外连接问题?
perl 如何联接数据库 远程的oracle
关于ORACLE数据库的运行效率
那裏有oracle数据库的课件