如何查询oracle一个数据库中包含有某个特定值的所有表及字段名

 我来答
twvampire
推荐于2016-10-10 · TA获得超过3620个赞
知道大有可为答主
回答量:3029
采纳率:76%
帮助的人:2988万
展开全部

转:

怎么在某Schame下搜索数据:
比如:在scott用户下面,搜索含有'TEST'的数据的表和字段


穷举法:

declare

  v_Sql   varchar2(2000);

  v_count number;

begin

  for xx in (select t.OWNER, t.TABLE_NAME, t.COLUMN_NAME

               from dba_tab_columns t

              where t.OWNER = 'SCOTT') loop

    begin

      v_Sql := 'select count(1) from ' || xx.owner || '.' || xx.table_name ||

               ' where ' || xx.column_name || ' like ''%TEST%'' ';

      execute immediate v_Sql

        into v_count;

      if (v_count >= 1) then

        dbms_output.put_line(xx.table_name || ':' || xx.column_name);

      end if;

    exception

      when others then

        null;

    end;

  end loop;

end;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式