I need to search our oracle database for a string in all tables and columns. I have the below query I found online but when I execute it I get the following error
Any help is appreciated
ORA-06550: line 6, column 31:
PL/SQL: ORA-00904: "COLUMN_NAME": invalid identifier
ORA-06550: line 6, column 12:
PL/SQL: SQL Statement ignored
ORA-06550: line 8, column 30:
PLS-00364: loop index variable 'T' use is invalid
ORA-06550: line 7, column 4:
PL/SQL: Statement ignored
ORA-06550: line 12, column 38:
PLS-00364: loop index variable 'T' use is invalid
ORA-06550: line 12, column 16:
PL/SQL: Statement ignored
BEGIN
FOR t IN (SELECT table_name, column_name FROM all_tables) LOOP
EXECUTE IMMEDIATE
'SELECT COUNT(*) FROM '||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.table_name ||' '||t.column_name||' '||match_count );
END IF;
END LOOP;
END;
/
At a minimum, you need to query ALL_TAB_COLUMNS, not ALL_TABLES
If you are looking for a string, however, you would almost certainly want to restrict yourself to looking for columns that could store a string. It wouldn’t make sense, for example, to search a DATE column for a string. And unless you have a great deal of a priori knowledge about what a BLOB column contains and the ability to parse the BLOB column’s binary formatting, it wouldn’t make sense to search a BLOB column for a string. Given that, I suspect you want something more like
Of course, this is going to be insanely slow– you’d full scan every table once for every string column in the table. With moderately large tables and a moderate number of string columns, that is likely to take quite a while.