martes, marzo 17, 2009

Buscando texto en Oracle data base

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.

1 comentario:

mchaconr dijo...

Informe de error:
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