首页 > 数据库 > Oracle > 正文

Oracle 数据库系统使用经验

2024-08-29 13:44:05
字体:
来源:转载
供稿:网友
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 ...); 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 选项保证第二次输入既使对象存在的情况下也能成功 .

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表