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是这个星球上最强大的关系型数据库,只要有想法,没什么不可能,只要你肯动脑子,肯查资料,解决方案是一定会有的。