Ir al contenido principal

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.

Comentarios

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

Entradas más populares de este blog

Impensando acerca de las referencias en Java

Fue hace ya algún tiempo que pase un rato discutiendo con algunos compañeros acerca de si existe o no el paso por referencia; el discurso fue mucho hacia que en Java el comportamiento, en el supuestamente pasamos por referencia un objeto y por valor los objetos primitivos creo mucha polémica. Para ubicarnos en contexto veamos el siguiente ejemplo. public static void main(String[] args) { int value = 10; changeValue(value); System.out.println("value = " + value); User user = new User(); Name name = new Name(); user.setName(name); name.setName("jsanca"); name.setLastName("XXX"); user.setPassword("123queso"); System.out.println("user: " + user.getName().getName() + ", " + user.getName().getLastName() + ", " + user.getPassword()); changeValue1(user); System.out.println("user: " + user.getName().getName() + ", " + user.getName().getLastName() + ", " + user.ge...

Ideas para un eco-hogar

Un Eco Hogar, Ultimamente he estado pensando al respecto (en la implementación de una casa ecológica), leyendo un poco me entero que existen diferentes alternativas para el ahorro de consumo electrico del hogar; paneles solares, mini hidro turbinas, energía eólica, etc. Algunas alternativas interesantes representan los termos calentados por paneles solares, para no gastar energía en la ducha caliente, etc. Todas estas alternativas están muy bien, aunque la inversión por el momento es algo grande para un hogar promedio, con el consumo masivo, podría convertirse en una opción de facto. Estas opciones representa un ahorro en el consumo eléctrico, pero que hay con el consumo del H2O; sin necesidad de ser muy observador, nos damos cuenta que uno de los mayores puntos donde se desperdicia agua son: el baño y la ducha. En cuanto a la ducha no se me ocurre mas que algunos habitos en vez de soluciones tecnicas, como mojarse, cerrar el tuvo, enjabonarse, etc. Cerrar el tuvo cuando no lo estamos ...

Wikipedia data base schema

Algo interesante como caso de estudio, especialmente para los que estén cursando bases de datos, el esquema de la Wikipedia esta disponible para hechar un ojo. A simple vista, me gusta mucho la simplicidad y lo bien documentada que se encuentra, vale la pena dedicarle un tiempo. http://www.wikipedia.org/