El siguiente script, nos es útil cuando deseamos buscar texto dentro de una base de datos Oracle, la idea es buscar en todas las tablas del esquema, así como en todas las columnas, es útil cuando queremos saber si un texto se encuentra dentro de alguna columna, a continuación el código:
SET SERVEROUTPUT ON SIZE 100000
DECLARE
match_count INTEGER;
BEGIN
FOR t IN (SELECT table_name, column_name, data_type FROM user_tab_columns) LOOP
--dbms_output.put_line( t.table_name ||' '||t.column_name );
IF t.data_type = 'VARCHAR2' THEN
EXECUTE IMMEDIATE
'SELECT COUNT(*) FROM '||t.table_name||' WHERE '||t.column_name||' like :1 '
INTO match_count
USING 'algun texto aqui';
IF match_count > 0 THEN
dbms_output.put_line( t.table_name ||' '||t.column_name||' '||match_count );
END IF;
END IF;
END LOOP;
END;
Simplemente, cambie la línea:
USING 'algún texto aquí';
Por el texto o criterio de búsqueda que desea.
SET SERVEROUTPUT ON SIZE 100000
DECLARE
match_count INTEGER;
BEGIN
FOR t IN (SELECT table_name, column_name, data_type FROM user_tab_columns) LOOP
--dbms_output.put_line( t.table_name ||' '||t.column_name );
IF t.data_type = 'VARCHAR2' THEN
EXECUTE IMMEDIATE
'SELECT COUNT(*) FROM '||t.table_name||' WHERE '||t.column_name||' like :1 '
INTO match_count
USING 'algun texto aqui';
IF match_count > 0 THEN
dbms_output.put_line( t.table_name ||' '||t.column_name||' '||match_count );
END IF;
END IF;
END LOOP;
END;
Simplemente, cambie la línea:
USING 'algún texto aquí';
Por el texto o criterio de búsqueda que desea.
Comentarios
ORA-00904: "CEDULA": identificador no válido
ORA-06512: en línea 7
00904. 00000 - "%s: invalid identifier"
*Cause:
*Action:
COB_PATEN_LIC NUM_PATENTE 2
DATOS_DIREC_PATENTES NUM_PATENTE 1
DATOS_PROP_PAT_LICORES NUM_PATENTE 1
COB_PATEN_LIC NUM_PATENTE 2
DATOS_DIREC_PATENTES NUM_PATENTE 1
DATOS_PROP_PAT_LICORES NUM_PATENTE 1