oracle查询所有表的方法

oracle查询所有表和所有数据的方法可能许多刚刚接触oracle数据库的新人都不太了解,下面就为您详细介绍oracle查询所有表的方法,供您参考。

为容县等地区用户提供了全套网页设计制作服务,及容县网站建设行业解决方案。主营业务为成都网站制作、成都网站建设、容县网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

 
 
 
  1. SELECT t.data_type  
  2. FROM user_tab_columns t  
  3. GROUP BY t.data_type;  
  4. -- Created on 2010-8-26 by RONGZHI_LI  
  5. DECLARE  
  6. CURSOR ot(namelike IN VARCHAR2)  
  7. IS  
  8. (SELECT owner AS uname,  
  9. object_name AS tname  
  10. FROM all_objects  
  11. WHERE object_type='TABLE' 
  12. AND owner LIKE namelike  
  13. );  
  14. CURSOR tc( username IN all_tab_columns.owner%TYPE, tablename IN all_tab_columns.table_name%type)  
  15. IS  
  16. (SELECT t.OWNER AS uname,  
  17. t.table_name  AS tab,  
  18. t.column_name AS col,  
  19. t.data_type data  
  20. FROM all_tab_columns t  
  21. WHERE t.owner    = username 
  22. AND t.table_name = tablename 
  23. );  
  24. sqlstr       VARCHAR2(200);  
  25. findsqlstr   VARCHAR2(200);  
  26. foundcount   NUMBER;  
  27. data_type    VARCHAR2(100):='';  
  28. logic_symbol VARCHAR2(10) :='=';  
  29. data_value   VARCHAR2(100);  
  30. --自行设定  
  31. name_like  VARCHAR2(100):='%HS_%';  
  32. find_type  VARCHAR2(100):='varchar2';--'varchar2';number  
  33. find_value VARCHAR2(100):='工行';  
  34. use_like   BOOLEAN      :=true;  
  35. BEGIN  
  36. data_type  := upper(find_type);  
  37. data_value :=find_value;--先给默认值 

--1.判断类型,是否为字符串

 
 
 
  1. IF data_type  = 'VARCHAR2' THEN        -- 对于字符串特别判定  
  2. data_value := ''''||find_value||'''';--注意:pl/sql显示' '为''  
  3. END IF; 

--2.判断是否使用like 这个应该跟varchar2类型配合

 
 
 
  1. IF use_like THEN  
  2. logic_symbol:=' like ';  
  3. data_value  := '''%'||find_value||'%''';--注意:pl/sql显示' '为''  
  4. END IF;  
  5. --  
  6. FOR aot IN ot(name_like)  
  7. LOOP  
  8. FOR atc IN tc(aot.uname,aot.tname)  
  9. LOOP  
  10. foundcount :=0;  
  11. IF atc.DATA = data_type THEN  
  12. sqlstr   := 'select count(*)  from '|| atc.uname ||'.' || atc.tab || ' where ' || atc.col  
  13. || logic_symbol || data_value;  
  14. --dbms_output.put_line(sqlstr);--debug用  
  15. EXECUTE immediate sqlstr INTO foundcount;  
  16. IF foundcount > 0 THEN  
  17. findsqlstr := 'select *  from ' || atc.uname ||'.' || atc.tab || ' where ' || atc.col ||  
  18. logic_symbol || data_value||';--'||foundcount;  
  19. dbms_output.put_line(findsqlstr);  
  20. END IF;  
  21. END IF;  
  22. END LOOP;  
  23. END LOOP;  
  24. dbms_output.put_line('查找结束');  
  25. END; 

 

以上就是oracle查询所有表的方法介绍。

网站栏目:oracle查询所有表的方法
标题网址:http://www.csdahua.cn/qtweb/news40/145140.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网