Oracle数据库的系统中6个经验原则

以下的文章主要是对Oracle数据库的系统中经常使用的相关经验原则,本文对其分成六部分介绍,其中包括having 子句的具体用法 ,外部联接”+”的实际应用,还有如何删除表内重复记录的实际操作方法 。

1.having 子句的用法

having 子句对 group by 子句所确定的行组进行控制,having 子句条件中只允许涉及常量,聚组函数或group by 子句中的列.

2.外部联接”+”的用法

外部联接”+”按其在”=”的左边或右边分左联接和右联接.若不带”+”运算符的表中的一个行不直接匹配于带”+”预算符的表中的任何行,则前者的行与后者中的一个空行相匹配并被返回.若二者均不带’+’,则二者中无法匹配的均被返回.利用外部联接”+”,可以替代效率十分低下的 not in 运算,大大提高运行速度.例如,下面这条命令执行起来很慢

 

  1. select a.empno from emp a where a.empno not in   
  2. (select empno from emp1 where job=’SALE’);   

 

倘若利用外部联接,改写命令如下:

 

  1. select a.empno from emp a ,emp1 b   
  2. where a.empno=b.empno(+)   
  3. and b.empno is null   
  4. and b.job=’SALE’;   

 

可以发现,运行速度明显提高.

3.删除表内重复记录的方法

可以利用这样的命令来删除表内重复记录:

 

  1. delete from table_name a   
  2. where rowid< (select max(rowid) from table_name   
  3. where column1=a.column1 and column2=a.column2   
  4. and colum3=a.colum3 and ...);   

 

不过,当表比较大(例如50万条以上)时,这个方法的效率之差令人无法忍受,需要另想办法(可参看拙文《电信计费中长途重复话单的技术处理》,《计算机与通信》,1999-07).

4.set transaction 命令的用法

在执行大事务时,有时oracle会报出如下的错误:

 

  1. ORA-01555:snapshot too old (rollback segment too small)  

这说明oracle给此事务随机分配的回滚段太小了,这时可以为它指定一个足够大的回滚段,以确保这个事务的成功执行.例如

 

  1. set transaction use rollback segment roll_abc;   
  2. delete from table_name where ...   
  3. commit;   

 

回滚段roll_abc被指定给这个delete事务,commit命令则在事务结束之后取消了回滚段的指定.

5.使用索引的注意事项

select,update,delete 语句中的子查询应当有规律地查找少于20%的表行.如果一个语句查找的行数超过总行数的20%,它将不能通过Oracle数据库系统使用索引获得性能上的提高.

索引可能产生碎片,因为记录从表中删除时,相应也从表的索引中删除.表释放的空间可以再用,而索引释放的空间却不能再用.频繁进行删除操作的被索引的表,应当阶段性地重建索引,以避免在索引中造成空间碎片,影响性能.在许可的条件下,也可以阶段性地truncate表,truncate命令删除表中所有记录,也删除索引碎片.

6.数据库重建应注意的问题

在利用import进行Oracle数据库重建过程中,有些视图可能会带来问题,因为结构输入的顺序可能造成视图的输入先于它低层次表的输入,这样建立视图就会失败.要解决这一问题,可采取分两步走的方法:首先输入结构,然后输入数据.命令举例如下 (uesrname:jfcl,password:hfjf,host sting:ora1,数据文件:expdata.dmp):

 

  1. imp jfcl/hfjf@ora1 file=empdata.dmp rows=N   
  2. imp jfcl/hfjf@ora1 file=empdata.dmp full=Y buffer=64000   
  3. commit=Y ignore=Y   

 

第一条命令输入所有Oracle数据库结构,但无记录.第二次输入结构和数据,64000字节提交一次.ignore=Y选项保证第二次输入既使对象存在的情况下也能成功.

文章出自:http://www.programbbs.com/doc/class10-3.htm

【编辑推荐】

  1. 修改Oracle最大连接数的步骤有哪些
  2. Oracle EM管理 MySQL的实操方案
  3. Oracle In-Memory Undo特性浅谈
  4. Oracle DRCP与PHP的不同之处
  5. Oracle 语句的优化规则中的相关项目

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/282925.html<

(0)
管理的头像管理
上一篇2025-05-13 16:51
下一篇 2025-05-13 16:52

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注