【发布时间】:2016-10-26 00:34:40
【问题描述】:
我知道这是一个重复的问题,但我找不到重新开始讨论的方法。我试图创建一个存储过程,它将在所有表中的所有列中搜索一个值。这是我到目前为止创建的:
CLEAR SCREEN
SET VERIFY OFF
ACCEPT val CHAR PROMPT 'What value do you want to search for: '
CLEAR SCREEN;
DECLARE
match_count integer;
v_search_string varchar2(4000) := <<val>>;
BEGIN
FOR t IN (SELECT owner,
table_name,
column_name
FROM all_tab_columns
WHERE data_type in ('CHAR', 'VARCHAR2', 'NCHAR', 'NVARCHAR2',
'CLOB', 'NCLOB') )
LOOP
BEGIN
EXECUTE IMMEDIATE
'SELECT COUNT(*) FROM '||t.owner || '.' || t.table_name||
' WHERE '||t.column_name||' = :1'
INTO match_count
USING v_search_string;
IF match_count > 0 THEN
dbms_output.put_line( t.owner || '.' || t.table_name ||' '||t.column_name||' '||match_count );
END IF;
EXCEPTION
WHEN others THEN
dbms_output.put_line( 'Error encountered trying to read ' ||
t.column_name || ' from ' ||
t.owner || '.' || t.table_name );
END;
END LOOP;
END;
/
但我得到了错误。任何帮助将不胜感激!
【问题讨论】:
-
嗯,有什么错误!?
-
你能找到你复制的问题吗?这也有帮助