Oracle数据库系统使用经验六则

 更新时间:2007年03月07日 00:00:00   作者:  
正在看的ORACLE教程是:Oracle数据库系统使用经验六则。

 1.having 子句的用法 

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

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

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


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


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

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

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


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

[NextPage]

4.set transaction 命令的用法 

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


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


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

  5.使用索引的注意事项 

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

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

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

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


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

上一页    

相关文章

  • Oracle merge合并更新函数实例详解

    Oracle merge合并更新函数实例详解

    这篇文章主要给大家介绍了关于Oracle merge合并更新函数的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • 解决plsql因事务未提交造成的锁表问题

    解决plsql因事务未提交造成的锁表问题

    这篇文章主要介绍了plsql因事务未提交造成的锁表的解决办法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • Oracle 获取表注释和列注释

    Oracle 获取表注释和列注释

    这篇文章主要介绍了Oracle 获取表注释和列注释的相关资料,需要的朋友可以参考下
    2017-07-07
  • Oracle中如何查看表空间使用率

    Oracle中如何查看表空间使用率

    这篇文章主要介绍了Oracle中如何查看表空间使用率问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Oracle实现查询2个日期所跨过的月份列表/日期列表的方法分析

    Oracle实现查询2个日期所跨过的月份列表/日期列表的方法分析

    这篇文章主要介绍了Oracle实现查询2个日期所跨过的月份列表/日期列表的方法,结合实例形式分析了Oracle日期相关查询与运算相关操作技巧,需要的朋友可以参考下
    2019-09-09
  • Oracle数据库正则表达式使用场景代码实例

    Oracle数据库正则表达式使用场景代码实例

    这篇文章主要介绍了Oracle数据库正则表达式使用场景代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Oracle 11.2.0.4打补丁的方法

    Oracle 11.2.0.4打补丁的方法

    这篇文章主要介绍了Oracle 11.2.0.4打补丁的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • DBF 文件恢复 ORACLE 数据库的方法

    DBF 文件恢复 ORACLE 数据库的方法

    这篇文章主要介绍了DBF 文件 ORACLE 数据库恢复的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • Oracle故障处理Rman-06207&Rman-06214的方法

    Oracle故障处理Rman-06207&Rman-06214的方法

    新搭建的环境,还没上线,今天在部署脚本,RMAN 备份中有一个警告,下面这篇文章主要给大家介绍了关于Oracle故障处理Rman-06207&Rman-06214的相关资料,需要的朋友可以参考下
    2022-11-11
  • Oracle 闪回 找回数据的实现方法

    Oracle 闪回 找回数据的实现方法

    闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复。这篇文章主要介绍了Oracle 闪回 找回数据的实现方法,需要的朋友可以参考下
    2018-09-09

最新评论