当前位置:数据库 > Oracle >>

oracle视图中有没有用到一张表

oracle视图中有没有用到一张表
 
问题原因:
 
1,文档不全
 
2,年久遗忘
 
3,员工离职
 
结果:一张表(XZF_CASE_DISCUSS)不知道这张表有什么用是否在视图中使用过,是废表吗?总不能一个个去看视图吧!
 
办法:当然不需要,oracle提供丰富的数据登记表和视图,所有的用户对象都可以查询,比如说我们想查视图就涉及到一张表:user_views
 
[sql] 
select * from user_views;  
 


 
 
请看TEXT字段,这里存储着视图生成的语句,我们只要遍历这些语句,查看其是否包含目标表名,即可知道哪儿使用了该表。
 
[sql] 
select instr(text,'XZF_CASE_DISCUSS',1,1) from user_views;  
这样似乎是问题解决了,但我突然发现忽略了一点,TEXT字段是LONG类型,因此我们只能接受出错的结果:
 
 
查了资料,发现LONG类型很不容易操作,是oracle不提倡的数据类型,这里虽然还在使用,估计很快就会失效吧。这里提供一个改进的办法:
 
[sql] 
Create TABLE testBak (col1 clob);    
  
insert into testBak select text from user_views;  
这样LONG类型的TEXT字段转换成clob类型的,对于clob类型我们就比较熟悉了,可以直接采用instr函数来操作,就可以了。
[sql] 
select instr(col1,'XZF_CASE_DISCUSS',1,1) from  testBak   
 
 
可以看到所有的记录都是0,说明在所有的视图中都没有用到过XZF_CASE_DISCUSS表,虽然不能断定该表是废表,但可以证明视图中没有这个东西。
 
总结:oracle是这个星球上最强大的关系型数据库,只要有想法,没什么不可能,只要你肯动脑子,肯查资料,解决方案是一定会有的。
 
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,