Foros del Web » Programando para Internet » PHP »

Ayuda con una query en MySQL, urgente ...

Estas en el tema de Ayuda con una query en MySQL, urgente ... en el foro de PHP en Foros del Web. Hola, haber si logro explicaros la consulta que quiero realizar, ya se que hay un foro de SQL pero es que tengo mucha prisa, gracias. ...
  #1 (permalink)  
Antiguo 05/06/2003, 04:40
 
Fecha de Ingreso: febrero-2003
Mensajes: 47
Antigüedad: 14 años, 10 meses
Puntos: 0
Ayuda con una query en MySQL, urgente ...

Hola, haber si logro explicaros la consulta que quiero realizar, ya se que hay un foro de SQL pero es que tengo mucha prisa, gracias.

Tengo tres tablas

1)Tabla Empleados

Campos:

Cod_Empleado
Nombre_Empleado
... etc

1,Juan; 2, Pedro; 3,Joaquín

2) Tabla Idiomas
Campos
Cod_Idioma
Nombre_Idioma

1,Inglés;2,Español;3,Francés

3)Tabla Idiomas_Empleados
Campos
CodEmpleado_ie
CodIdioma_ie

Es decir un Empleado puede hablar N idiomas
1,1;1,2;1,3;2,1;3,1

Mi consulta es sencilla pero no doy con ella, como hago para saber:
1) Los nombres de los empleados que hablan Ingles "Y" Francés "Y" Español.

2)El nombre de los empleados que habla Inglés "O" Francés "O" Español

MIL GRACIAS.
  #2 (permalink)  
Antiguo 05/06/2003, 05:09
Ex Colaborador
 
Fecha de Ingreso: junio-2002
Mensajes: 9.091
Antigüedad: 15 años, 6 meses
Puntos: 16
Hola,

¿En el foro de base de datos son lentos o es que nosotros somos mas rapidos?

En fin, la cuestion es que falta de aportar un dato importante: que base de datos usas. Porque estos problemas se pueden solucionar con subconsultas, que por ejemplo MySQL no soporta (en versiones 3.23.x al menos). Aunque la segunda tiene una solucion sin subconsultas:

select distinct campos que quieras leer from Empleados left join Idiomas_Empleados on CodEmpleado_ie=Cod_Empleado where CodIdioma_ie=1 or CodIdioma_ie=2 or ...

Para la primera, sin usar subconsultas, se me ocurre hacer tres consultas para obtener el listado de cod de empleados que tiene cada idioma y una cuarta consulta cogiendo los registros de empleados cuyo cod este en una de las 3 listas:

select CodEmpleado_ie from Idiomas_Empleados where CodIdioma_ie=1

guardamos el resultado el una lista de codigos separados por comas

idem para los otros idiomas

select campos de empleados from Empleados where Cod_Empleado IN (la lista del primer idioma) and Cod_Empleado IN (la lista del segundo idioma) and ...

Si tu base de datos permite subconsultas, seria solo la ultima consulta sustituyendo las listas por las subconsultas.

Espero haber sido de ayuda.

PD: Posiblemente haya otras soluciones mas optimas, pero es lo unico que se me ocurre ahora mismo.
__________________
Josemi

Aprendiz de mucho, maestro de poco.
  #3 (permalink)  
Antiguo 05/06/2003, 05:54
 
Fecha de Ingreso: febrero-2003
Mensajes: 47
Antigüedad: 14 años, 10 meses
Puntos: 0
Gracias por responder

No he querido decir que sean lentos, lo que pasa es que estoy un poco stresado y ya sabes.

Por cierto La consulta para el AND por subconsultas (yo tengo el Mysql 3.23.x y no soporta subconsultas) funciona GRACIAS, aunque no existe un sistema más sencillo?

Gracias
  #4 (permalink)  
Antiguo 05/06/2003, 12:19
O_O
 
Fecha de Ingreso: enero-2002
Ubicación: Santiago - Chile
Mensajes: 34.417
Antigüedad: 15 años, 11 meses
Puntos: 126
Pues no existe forma mas sencilla en Mysql (por lo menos para tu versión de Msyql ..).

Mysql 4.1 (todavía en fase Alfa) ya incorpora sub-consultas según el standard ISO no secuantos del SQL ..

Me refiero a sub-consultas típo:
SELECT * FROM table1 WHERE id IN (SELECT id FROM table2);


Un saludo,
__________________
Por motivos personales ya no puedo estar con Uds. Fue grato haber compartido todos estos años. Igualmente los seguiré leyendo.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 23:11.