数据库系统使用经验牛
药膳食疗 2021年09月06日 浏览:4 次
ving 子句的用法 having 子句对 group by 子句所确定的行组进行控制 ,having 子句条件中只允许涉及常量 , 聚组函数或 group by 子句中的列 .
2. 外部联接 \"+\" 的用法
外部联接 \"+\" 按其在 \"=\" 的左边或右边分左联接和右联接 . 若不带 \"+\" 运算符的表中的一个行不直接匹配于带 \"+\" 预算符的表中的任何行 , 则前者的行与后者中的一个空行相匹配并被返回 . 若二者均不带 \'+\', 则二者中无法匹配的均被返回 . 利用外部联接 \"+\", 可以替代效率十分低下的 not in 运算 , 大大提高运行速度 . 例如 , 下面这条命令执行起来很慢
select pno from emp a where pno not in
(select empno from emp1 where job=\'SALE\');
倘若利用外部联接 , 改写命令如下 :
select pno from emp a ,emp1 b
where pno=pno(+)
and pno is null
and b=\'SALE\';
可以发现 , 运行速度明显提高 .
3. 删除表内重复记录的方法
可以利用这样的命令来删除表内重复记录 :
delete from table_name a
内地的观众可能不太熟悉。Makiyo是中日混血儿 where rowid (select max(rowid) from table_name
where column1=lumn1 and column2=lumn2
and colum3=lum3 and ...);
t 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, 数据文件 :p):
imp jfcl/hfjf@ora1 file=p rows=N
imp jfcl/hfjf@ora1 file=p full=Y buffer=64000
commit=Y ignore=Y
第一条命令输入所有数据库结构 , 但无记录 . 第二次输入结构和数据 ,64000 字节提交一次 .ignore=Y 选项保证第二次输入既使对象存在的情况下也能成功 .
查看本文来源
成都哪家男科医院好孩子不爱吃饭怎么办
苏州白癜风医院哪家好

- 上一篇: 数据库管理脚本命名规范覆盖
- 下一篇 数据库系统使用经验六则呢
-
花絮波兰球迷助阵中国女排
2020-08-11
-
刮痧治疗肩周炎3
2019-07-16
-
厦门市中医院获得中医药管理局国际合作司中
2019-07-15
-
重庆市发布关于加强儿童中医医疗卫生服务能
2019-07-11
-
分析鸽子汤的养生价值
2019-07-11
-
鳄鱼肉是功效与作用
2019-07-07