Oracle数据库系统使用经验

时间:2021-04-16

  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

  and column1=a.column1 and column2=a.column2

  and colum3=a.colum3 and ...);

  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 选项保证第二次输入既使对象存在的情况下也能成功 .

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章