欢迎投稿

今日深度:

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

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


问题原因:

1,文档不全

2,年久遗忘

3,员工离职

结果:一张表(XZF_CASE_DISCUSS)不知道这张表有什么用是否在视图中使用过,是废表吗?总不能一个个去看视图吧!

办法:当然不需要,oracle提供丰富的数据登记表和视图,所有的用户对象都可以查询,比如说我们想查视图就涉及到一张表:user_views

select * from user_views;

请看TEXT字段,这里存储着视图生成的语句,我们只要遍历这些语句,查看其是否包含目标表名,即可知道哪儿使用了该表。

select instr(text,'XZF_CASE_DISCUSS',1,1) from user_views;
这样似乎是问题解决了,但我突然发现忽略了一点,TEXT字段是LONG类型,因此我们只能接受出错的结果:

查了资料,发现LONG类型很不容易操作,是oracle不提倡的数据类型,这里虽然还在使用,估计很快就会失效吧。这里提供一个改进的办法:

Create TABLE testBak (col1 clob);  

insert into testBak select text from user_views;
这样LONG类型的TEXT字段转换成clob类型的,对于clob类型我们就比较熟悉了,可以直接采用instr函数来操作,就可以了。

select instr(col1,'XZF_CASE_DISCUSS',1,1) from  testBak 

可以看到所有的记录都是0,说明在所有的视图中都没有用到过XZF_CASE_DISCUSS表,虽然不能断定该表是废表,但可以证明视图中没有这个东西。

总结:oracle是这个星球上最强大的关系型数据库,只要有想法,没什么不可能,只要你肯动脑子,肯查资料,解决方案是一定会有的。


www.htsjk.Com true http://www.htsjk.com/shujukunews/211.html NewsArticle oracle视图中有没有用到一张表 问题原因: 1,文档不全 2,年久遗忘 3,员工离职 结果:一张表(XZF_CASE_DISCUSS)不知道这张表有什么用是否在视图中使用过,是废表吗?总不能一个个去...
相关文章
    暂无相关文章
评论暂时关闭