Listado completo de tutoriales
32 - Búsqueda de patrones (regexp) |
Los operadores "regexp" y "not regexp" busca patrones de modo similar a "like" y "not like".
Para buscar libros que contengan la cadena "Ma" usamos:
select titulo from libros where titulo regexp 'Ma';
Para buscar los autores que tienen al menos una "h" o una "k" o una "w" tipeamos:
select autor from libros where autor regexp '[hkw]';
Para buscar los autores que no tienen ni "h" o una "k" o una "w" tipeamos:
select autor from libros where autor not regexp '[hkw]';
Para buscar los autores que tienen por lo menos una de las letras de la "a" hasta la "d", es decir, "a,b,c,d", usamos:
select autor from libros where autor regexp '[a-d]';
Para ver los títulos que comienzan con "A" tipeamos:
select titulo from libros where titulo regexp '^A';
Para ver los títulos que terminan en "HP" usamos:
select titulo from libros where titulo regexp 'HP$';
Para buscar títulos que contengan una "a" luego un caracter cualquiera y luego una "e" utilizamos la siguiente sentencia:
select titulo from libros where titulo regexp 'a.e';
El punto (.) identifica cualquier caracter.
Podemos mostrar los títulos que contienen una "a" seguida de 2 caracteres y luego una "e":
select titulo from libros where titulo regexp 'a..e';
Para buscar autores que tengan 6 caracteres exactamente usamos:
select autor from libros where autor regexp '^......$';
Para buscar autores que tengan al menos 6 caracteres usamos:
select autor from libros where autor regexp '......';
Para buscar títulos que contengan 2 letras "a" usamos:
select titulo from libros where titulo regexp 'a.*a';
El asterisco indica que busque el caracter inmediatamente anterior, en este caso cualquiera porque hay un punto.
Ingresemos al programa "Workbench" y ejecutemos el siguiente bloque de instrucciones SQL para utilizar patrones de búsqueda mediante ''regexp':
drop table if exists libros; create table libros( codigo int unsigned auto_increment, titulo varchar(40) not null, autor varchar(30), editorial varchar(15), precio decimal(5,2) unsigned, primary key(codigo) ); insert into libros (titulo,autor,editorial,precio) values('El aleph','Borges','Planeta',15.50); insert into libros (titulo,autor,editorial,precio) values('Martin Fierro','Jose Hernandez','Emece',22.90); insert into libros (titulo,autor,editorial,precio) values('Antologia poetica','J.L. Borges','Planeta',39); insert into libros (titulo,autor,editorial,precio) values('Aprenda PHP','Mario Molina','Emece',19.50); insert into libros (titulo,autor,editorial,precio) values('Cervantes y el quijote','Bioy Casare- J.L. Borges','Paidos',35.40); insert into libros (titulo,autor,editorial,precio) values('Manual de PHP', 'J.C. Paez', 'Paidos',19); insert into libros (titulo,autor,editorial,precio) values('Harry Potter y la piedra filosofal','J.K. Rowling','Paidos',45.00); insert into libros (titulo,autor,editorial,precio) values('Harry Potter y la camara secreta','J.K. Rowling','Paidos',46.00); insert into libros (titulo,autor,editorial,precio) values('Alicia en el pais de las maravillas','Lewis Carroll','Paidos',36.00); -- Para buscar libros cuyos títulos contengan la cadena "Ma" usamos: select titulo from libros where titulo regexp 'Ma'; -- Para buscar los registros cuyos autores tienen al menos una "h" o una "k" o una "w" tipeamos: select titulo,autor from libros where autor regexp '[hkw]'; -- Para buscar los libros cuyos autores no tienen ni "h" o una "k" o una "w" tipeamos: select titulo,autor from libros where autor not regexp '[hkw]'; -- Para buscar los autores que tienen por lo menos una de las letras de la "a" -- hasta la "d", es decir, "a,b,c,d", usamos: select autor from libros where autor regexp '[a-d]'; -- Para ver los títulos que comienzan con "A" tipeamos: select titulo from libros where titulo regexp '^A'; -- Para ver los títulos que terminan en "HP" usamos: select titulo from libros where titulo regexp 'HP$'; -- Para buscar títulos que contengan una "a" luego un caracter cualquiera y luego una "e": select titulo from libros where titulo regexp 'a.e'; -- Podemos mostrar los títulos que contienen una "a" seguida de 2 caracteres y luego una "e": select titulo from libros where titulo regexp 'a..e'; -- Para buscar autores que tengan 6 caracteres exactamente usamos: select autor from libros where autor regexp '^......$'; -- Para buscar autores que tengan al menos 6 caracteres usamos: select autor from libros where autor regexp '......'; -- Para buscar títulos que contengan 2 letras "a" usamos: select titulo from libros where titulo regexp 'a.*a';
Que nos genera una salida similar a esta: