Foros del Web » Programación para mayores de 30 ;) » Bases de Datos General » Mysql »

[SOLUCIONADO] Consultar por 2 campos que juntos forman un id

Estas en el tema de Consultar por 2 campos que juntos forman un id en el foro de Mysql en Foros del Web. Saludos, Yo trabajo bastante con SQL, pero luego de presentarse este problema, me puse a dudar de mis conocimientos, y luego de leer bastante, aprendi ...
  #1 (permalink)  
Antiguo 06/09/2013, 14:10
Avatar de fenix4  
Fecha de Ingreso: noviembre-2001
Ubicación: Caracas
Mensajes: 226
Antigüedad: 23 años
Puntos: 1
Pregunta Consultar por 2 campos que juntos forman un id

Saludos,

Yo trabajo bastante con SQL, pero luego de presentarse este problema, me puse a dudar de mis conocimientos, y luego de leer bastante, aprendi otras cosas, pero aun no consigo la respuesta a esta consulta. Me explico.

Estoy migrando 3 tablas que luego voy a fusionar en 1 y las uní todas en una vista union

Código MySQL:
Ver original
  1. SELECT 1 as 'tipo' , nro_exp FROM tabla_a
  2. SELECT 2 as 'tipo' , nro_exp FROM tabla_b
  3. SELECT 3 as 'tipo' , nro_exp FROM tabla_c

Esto me dio una vista con un 2 campos, lo que forman juntos como una clave única como esto
vista
tipo, nro_exp

1, 1
1, 2(eliminar)
1, 3(eliminar)
1, 4
1, 5
2, 1
2, 2
2, 3
3, 1
3, 2

Hasta aquí, todo va como deseo.

Quiero insertar estos valores en una tabla nueva, pero antes debo filtrar unos registros que están nulos. Pero para ello primero hago el Select que voy a hacer en la clausa Insert

Código MySQL:
Ver original
  1. SELECT  tipo, nro_exp FROM vista
  2. WHERE (tipo <> 1 AND nro_exp <> 2) OR (tipo <> 1 AND nro_exp <> 3)

Pero esto lo que hace es que no me trae todos los registros con tipo = 1 y solamente quiero eliminar los tipo 1 que sean nro_exp 2 y 3.

En realidad las tablas tienen muchos más registros y son varios los registros nulos a eliminar o no tomar en cuenta para la nueva tabla.

Gracias de antemano.
__________________
S.L.P.S.
  #2 (permalink)  
Antiguo 06/09/2013, 15:10
 
Fecha de Ingreso: febrero-2013
Ubicación: Lima
Mensajes: 301
Antigüedad: 11 años, 9 meses
Puntos: 5
Respuesta: Consultar por 2 campos que juntos forman un id

mmm....no entendi muy bien la pregunta....pero segun lo poco que entendi....te dejo este query...a ver si te es de utilidad....
Código MySQL:
Ver original
  1. SELECT  tipo, nro_exp
  2. FROM vista
  3. where tipo not in ('1')
  4. and nro_exp not in ('2','3');

saludos....
__________________
Lo que no se....tampoco creo saberlo....
  #3 (permalink)  
Antiguo 06/09/2013, 15:25
 
Fecha de Ingreso: noviembre-2012
Mensajes: 139
Antigüedad: 12 años
Puntos: 1
Respuesta: Consultar por 2 campos que juntos forman un id

dices que quieres los campos tipo y nro_exp de la tabla vista
Código SQL:
Ver original
  1. SELECT  tipo, nro_exp FROM vista
  2.     WHERE (tipo <> 1 AND nro_exp <> 2) OR (tipo <> 1 AND nro_exp <> 3)
si quieres que te devuelva los datos de tipo 1 coloca where tipo=1 and nro_exp=('2','3');
  #4 (permalink)  
Antiguo 09/09/2013, 07:35
Avatar de fenix4  
Fecha de Ingreso: noviembre-2001
Ubicación: Caracas
Mensajes: 226
Antigüedad: 23 años
Puntos: 1
Respuesta: Consultar por 2 campos que juntos forman un id

Gracias, si puedo imaginar lo confuso que es para muchos. Por eso trate te explicar bien.


Ambichol si hago eso no me va a traer los ortos tipo 1.
Falkon si hago eso no me va a traer los tipo 2 y 3.

Ok quiero seleccionar todos los registros menos uno que sea tipo 1 y nro_exp 2, y otro que sea tipo 1 pero nro_exp 3.

Osea igual me tiene que traer todos los tipo 1, 2 y 3, pero solo debe filtrar dos registros tipo 1.

Gracias
__________________
S.L.P.S.
  #5 (permalink)  
Antiguo 12/09/2013, 14:34
Colaborador
 
Fecha de Ingreso: enero-2007
Ubicación: México
Mensajes: 2.097
Antigüedad: 17 años, 10 meses
Puntos: 447
Respuesta: Consultar por 2 campos que juntos forman un id

Hola fenix4:

No sé si entendí correctamente, pero según los datos que pones podrías hacer esto:

Código MySQL:
Ver original
  1. mysql> SELECT * FROM tabla;
  2. +------+---------+
  3. | tipo | nro_exp |
  4. +------+---------+
  5. |    1 |       1 |
  6. |    1 |       2 |
  7. |    1 |       3 |
  8. |    1 |       4 |
  9. |    1 |       5 |
  10. |    2 |       1 |
  11. |    2 |       2 |
  12. |    2 |       3 |
  13. |    3 |       1 |
  14. |    3 |       2 |
  15. +------+---------+
  16. 10 rows in set (0.00 sec)
  17.  
  18. mysql> SELECT * FROM tabla
  19.        -> WHERE tipo != 1 OR (tipo = 1 AND nro_exp NOT IN (2, 3));
  20. +------+---------+
  21. | tipo | nro_exp |
  22. +------+---------+
  23. |    1 |       1 |
  24. |    1 |       4 |
  25. |    1 |       5 |
  26. |    2 |       1 |
  27. |    2 |       2 |
  28. |    2 |       3 |
  29. |    3 |       1 |
  30. |    3 |       2 |
  31. +------+---------+
  32. 8 rows in set (0.03 sec)

Saludos
Leo.
  #6 (permalink)  
Antiguo 17/09/2013, 13:57
Avatar de fenix4  
Fecha de Ingreso: noviembre-2001
Ubicación: Caracas
Mensajes: 226
Antigüedad: 23 años
Puntos: 1
Respuesta: Consultar por 2 campos que juntos forman un id

leonardo_josue

Gracias esto si resolvió mi problema, pero aun no comprendo como ?

Alguien me puede explicar?

Muchas gracias!!!
__________________
S.L.P.S.
  #7 (permalink)  
Antiguo 17/09/2013, 14:05
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años
Puntos: 2658
Respuesta: Consultar por 2 campos que juntos forman un id

Cita:
Gracias esto si resolvió mi problema, pero aun no comprendo como ?
¿No entiendes la lógica del WHERE que te pone Leo?
En realidad simplemente debes razonarlo recordando lo que hacen AND y OR, y cómo se usan los paréntesis.
Leo te plantea dos condiciones posibles:
Cita:
1) TIPO es diferente de 1;
2) TIPO es igual a 1 y NRO_EXP debe ser sí o si diferente de 2 o 3.
Lo que ha hecho @leonardo_josue es expresar las condiciones que quieres de una forma simple, eliminando todo lo superfluo.
Nada más que eso.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)
  #8 (permalink)  
Antiguo 17/09/2013, 14:21
Avatar de fenix4  
Fecha de Ingreso: noviembre-2001
Ubicación: Caracas
Mensajes: 226
Antigüedad: 23 años
Puntos: 1
Respuesta: Consultar por 2 campos que juntos forman un id

Listo, no se como no se me ocurrió.
__________________
S.L.P.S.

Etiquetas: campo, campos, consultar, insert, juntos, registros, select, sql, tabla
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 16:48.