首页  登陆  注册  博客集  下载频道  网络硬盘  学院论坛  家园
IT学院 网站地图 网站地图
收藏本站 收藏本站
高级搜索 高级搜索
 新闻IT新闻 互联网 微软 黑客新闻 网络网络协议 故障 网络管理 TCP/IP 无线技术 解决方案 黑客技术 漏洞 软件评测 安全资讯
 数据MSsql Oracle Mysql PL/SQL 备份 系统:Linux vista Windows FTP 防火墙 注册表 服务器行情 服务器应用 解决方案 WEB服务器
 墙纸风景壁纸 游戏壁纸 体育壁纸 汽车壁纸 人文壁纸 影视壁纸 广告壁纸 花卉壁纸 节日壁纸 动漫壁纸 明星壁纸 绘画壁纸 月历壁纸
当前位置: > 主页>数据库技术>Oracle>备份与恢复>Oracle数据库系统使用经验六则
热门文章排行
 
热门文章排行 Oracle 课程描述
Oracle数据库的灾难恢复
Oracle8i 概述
ORACLE 数据库备份技术
Oracle数据库系统使用经
在oracle中运行OS命令
Oracle dba 日常管理
ORACLE数据库的启动和关
如何在两个oracle服务器
关于恢复数据库的说明
精采文章推荐
 
精采文章推荐 Oracle数据库冷备份恢复
最新更新文章
 
最新更新文章 Oracle数据库冷备份恢复
ORACLE FOR SUN SOLARIS
Oracle 8.0使用技巧
其他数据库向Oracle8i的
Re: 紧急求救:oracle的
Re: 关于oracle的备份与
关于恢复数据库的说明
如何在两个oracle服务器
ORACLE数据库的启动和关
Oracle dba 日常管理

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

编辑:   来源:  日期:2008-02-06   我要投稿      家园

  1.having 子句的用法
  
  having 子句对 group by 子句所确定的行组进行控制,having 子句条件中只允许涉及常量,聚组函数或group by 子句中的列.
  
  2.外部联接"+"的用法
  
  外部联接"+"按其在"="的左边或右边分左联接和右联接.若不带"+"运算符的表中的一个行不直接匹配于带"+"预算符的表中的任何行,则前者的行与后者中的一个空行相匹配并被返回.若二者均不带’+’,则二者中无法匹配的均被返回.利用外部联接"+",可以替代效率十分低下的 not in 运算,大大提高运行速度.例如,下面这条命令执行起来很慢
  
  select a.empno from emp a where a.empno not in
  
  (select empno from emp1 where job=’SALE’);
  
  倘若利用外部联接,改写命令如下:
  
  select a.empno from emp a ,emp1 b
  
  where a.empno=b.empno(+)
  
  and b.empno is null
  
  and b.job=’SALE’;
  
  可以发现,运行速度明显提高.
  
  3.删除表内重复记录的方法
  
  可以利用这样的命令来删除表内重复记录:
  
  delete from table_name a
  
  where rowid< (select max(rowid) from table_name
  
  where column1=a.column1 and column2=a.column2
  
  and colum3=a.colum3 and ...);
  
  不过,当表比较大(例如50万条以上)时,这个方法的效率之差令人无法忍受,需要另想办法(可参看拙文《电信计费中长途重复话单的技术处理》,《计算机与通信》,1999-07).
  
  
  4.set transaction 命令的用法
  
  在执行大事务时,有时oracle会报出如下的错误:
  
  ORA-01555:snapshot too old (rollback segment too small)
  
  这说明oracle给此事务随机分配的回滚段太小了,这时可以为它指定一个足够大的回滚段,以确保这个事务的成功执行.例如
  
  set transaction use rollback segment roll_abc;
  
  delete from table_name where ...
  
  commit;
  
  回滚段roll_abc被指定给这个delete事务,commit命令则在事务结束之后取消了回滚段的指定.
  
  5.使用索引的注意事项
  
  select,update,delete 语句中的子查询应当有规律地查找少于20%的表行.如果一个语句查找的行数超过总行数的20%,它将不能通过使用索引获得性能上的提高.
  
  索引可能产生碎片,因为记录从表中删除时,相应也从表的索引中删除.表释放的空间可以再用,而索引释放的空间却不能再用.频繁进行删除操作的被索引的表,应当阶段性地重建索引,以避免在索引中造成空间碎片,影响性能.在许可的条件下,也可以阶段性地truncate表,truncate命令删除表中所有记录,也删除索引碎片.
  
  6.数据库重建应注意的问题
  
  在利用import进行数据库重建过程中,有些视图可能会带来问题,因为结构输入的顺序可能造成视图的输入先于它低层次表的输入,这样建立视图就会失败.要解决这一问题,可采取分两步走的方法:首先输入结构,然后输入数据.命令举例如下 (uesrname:jfcl,password:hfjf,host sting:ora1,数据文件:expdata.dmp):
  
  imp jfcl/hfjf@ora1 file=empdata.dmp rows=N
  
  imp jfcl/hfjf@ora1 file=empdata.dmp full=Y buffer=64000
  
  commit=Y ignore=Y
  
  第一条命令输入所有数据库结构,但无记录.第二次输入结构和数据,64000字节提交一次.ignore=Y选项保证第二次输入既使对象存在的情况下也能成功.


上一篇:ORACLE 数据库备份技术  
下一篇:在oracle中运行OS命令
 关键字:  
文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【论坛讨论

   相关文章:

   文章评论:(0条)
  
 请留名: 匿名评论   点击查看所有评论
 

  责任编辑:IT学院  声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。