博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle 中 根据值 查询 所在 表和字段
阅读量:5997 次
发布时间:2019-06-20

本文共 2699 字,大约阅读时间需要 8 分钟。

---------------------- 这里是查询 数字型字段值/*declareCURSOR cur_query IS  select table_name, column_name, data_type from user_tab_columns;  a number;  sql_hard varchar2(2000);  vv number;begin  for rec1 in cur_query loop  a:=0;  if rec1.data_type ='NUMBER' THEN  a := 1;  end if;  if a>0 then  sql_hard := '';  sql_hard := 'SELECT count(*) FROM  '|| rec1.table_name ||' where '  ||rec1.column_name|| '=''TYRCE0BF26AB5C586B3 '' ';  dbms_output.put_line(sql_hard);   execute immediate sql_hard INTO vv;  IF vv > 0 THEN   dbms_output.put_line(rec1.table_name||'--'||rec1.column_name);  end if;   END IF;  end loop;end;*/

 

查询字符串类型:

declareCURSOR cur_query IS  select a.table_name, a.column_name, a.data_type from user_tab_columns a         where 1=1         and (lower(a.data_type) = 'varchar2' or lower(a.data_type) = 'char')         and NOT a.TABLE_NAME like '%$%'         and NOT a.TABLE_NAME like '%+%'         and NOT a.TABLE_NAME like '%=%'         ORDER BY A.TABLE_NAME ASC  ;  a number;  sql_hard varchar2(2000);  vv number;  rscount number;  str varchar2(2000);  num number;  findValue varchar2(500) :='R2186E3DC09B88E1AF  ';   -- 要查询的字符串值begin  rscount:=0;     str:='TRUNCATE table tmp_test';    execute immediate str;      str:='drop table tmp_test';    execute immediate str;      str:='CREATE GLOBAL TEMPORARY TABLE tmp_test (tab_name varchar2(500), col_name varchar2(500))  ON COMMIT PRESERVE ROWS';    execute immediate str;    ----使用动态SQL语句来执行  for rec1 in cur_query loop        rscount:= rscount + 1;        a:=0;        --if rec1.data_type ='VARCHAR2' or rec1.data_type='CHAR' THEN        if rec1.data_type ='VARCHAR2' or rec1.data_type='CHAR' THEN        a := 1;        end if;        if a>0 then              sql_hard := '';              sql_hard := 'SELECT count(*) FROM  '|| rec1.table_name ||' where '              --||rec1.column_name|| ' =''wu''';              ||rec1.column_name|| ' ='''|| findValue || '''';              --dbms_output.put_line(sql_hard);              --dbms_output.put_line( '**** ' || rec1.table_name||'--'||rec1.column_name);              execute immediate sql_hard INTO vv;              IF NVL(vv,0) > 0 THEN               dbms_output.put_line(rec1.table_name||'--'||rec1.column_name);                  str:= 'insert into tmp_test '                        || ' select ''' || rec1.table_name ||  ''' as tab_name,''' || rec1.column_name || ''' as col_name from dual';                                    execute immediate str;                                    str:= 'commit';                  execute immediate str;              end if;         END IF;  end loop;   --str:= 'select * from tmp_test'; --execute immediate str; end;-- 运行完以后 执行/*select * from tmp_test;*/

 

转载地址:http://cgmlx.baihongyu.com/

你可能感兴趣的文章
【翻译自mos文章】注意: ASMB process exiting due to lack of ASM file activity
查看>>
Linux 线程浅析
查看>>
ucgui界面设计演示样例2
查看>>
蓝桥杯练习系统——基础练习 十六进制转十进制
查看>>
Mac: Android studio+VirtualBox+Genymotion
查看>>
The way to Go(4): Go runtime及解释器
查看>>
keepalived+mysql backup服务器可ping通过vip但telnet vip+3306失败问题
查看>>
也谈免拆机破解中兴B860av1.1(解决不能安装软件/解决遥控)
查看>>
修改 Linux VM 中单个用户最大进程数的限制
查看>>
银行家算法
查看>>
react-native run-android error: unknown host service
查看>>
简易RPC框架-上下文
查看>>
26.使用IntelliJ IDEA开发Java Web项目时,修改了JSP后刷新浏览器无法及时显示修改后的页面...
查看>>
自定义ViewGroup
查看>>
25.管道流
查看>>
2017-2018:时间戳
查看>>
rsync(六)命令中文手册
查看>>
php实现 明明的随机数
查看>>
Guava中针对集合的 filter和过滤功能
查看>>
小程序顶部导航栏的自定义
查看>>