Foros del Web » Programando para Internet » PHP »

Problema con SELECT anidados

Estas en el tema de Problema con SELECT anidados en el foro de PHP en Foros del Web. Estimados amigos, Tengo un serio problema con la obtención de resultado a través de la utilización de array para implementar SELECT anidados, en PHP. Mucho ...
  #1 (permalink)  
Antiguo 03/05/2004, 02:02
 
Fecha de Ingreso: octubre-2003
Ubicación: Santiago
Mensajes: 66
Antigüedad: 14 años, 2 meses
Puntos: 0
Problema con SELECT anidados

Estimados amigos,

Tengo un serio problema con la obtención de resultado a través de la utilización de array para implementar SELECT anidados, en PHP.

Mucho les agradecería pudiesen decirme qué está malo o bien, que otra opción tengo para dicha implementación. No he logrado que esto funcione desde ya hace dos semanas...

Código PHP.
========

if ( $ciudad_1 != "")
{
$SQLQuery1 = "select codigo_Red from detalle_programas where city_1 = '$ciudad_1'";

$Tabla1=mysql_db_query($Database, $SQLQuery1, $IdConect);
$ctr=array();
while ($Registro = mysql_fetch_assoc($Tabla1))
{
$ctr[] = $Registro['codigo_Red'];
}
$listactr = implode (',',$ctr);
$SQLQuery2 = "select codigo_operador from programas where codigo_Red IN ($listactr)";

$Tabla2=mysql_db_query($Database, $SQLQuery2, $IdConect);
$ctr=array();
while ($Registro = mysql_fetch_assoc($Tabla2))
{
$ctr[] = $Registro['codigo_operador'];
}
$listactr = implode (',',$ctr);
$SQLQuery3 = "select codigo_operador, nombre_operador from operadores where codigo_operador IN ($listactr)";
$Tabla3=mysql_db_query($Database, $SQLQuery3, $IdConect);


El problema se presenta, al tratar de trabajar con la segunda query, es decir, el array $ctr, contiene los valores adecuados para operar con el SQLQuery2, el cual trabaja con la cadena $listactr, pero al intentar completar el segundo array $ctr, desde la query que le precede éste está vacío, por lo cual no se logra concretar el query para el SQLQuery3.

Ejemplo de output.
==============

output de primera cadena $listactr
--------------------------------------------
001,002

=====================================

entrada/salida utilizando dicha cadena en la query3

select codigo_operador, nombre_operador from operadores where codigo_operador IN ()

======================================


Muchas gracias por vuestra ayuda, cualquiera sea !
__________________
Saludos,

MAC
  #2 (permalink)  
Antiguo 03/05/2004, 02:16
Ex Colaborador
 
Fecha de Ingreso: junio-2002
Mensajes: 9.091
Antigüedad: 15 años, 6 meses
Puntos: 16
Hola,

Hipotesis: codigo_Red es un campo tipo texto. En ese caso, el IN deberia ser:

IN ('001','002')

Asi que el primer $listactr deberia sera algo como:
Código PHP:
 $listactr "'".implode ("','",$ctr)."'"
(espero que se distingan las ' y las ").

Saludos.
__________________
Josemi

Aprendiz de mucho, maestro de poco.
  #3 (permalink)  
Antiguo 03/05/2004, 02:45
 
Fecha de Ingreso: octubre-2003
Ubicación: Santiago
Mensajes: 66
Antigüedad: 14 años, 2 meses
Puntos: 0
Jose Miguel,

Muchas gracias por tu ayuda. Era exactamente eso, el campo había sido definido como varchar, y yo al tomar el caso consideré a dicho campo como numérico.

Ahora bien, una consulta (dentro de tu tiempo) para mi cultura. Por que se debe anteponer la secuencia de comillas simples (que a todo esto se distinguieron muy bien), es decir:

$listactr = " ' ".implode (" ',' ",$ctr)." ' ";


La secuencia de puntos antes y posterior al uso de implode...¿?
Pensé que la función implode, generaba la cadena, y que sólo habría bastado incluir las comillas simples dentro del paréntesis. Pero realicé una prueba y no funcionó. Por qué ?

Gracias nuevamente por tu apoyo...esto ya está funcionando.
__________________
Saludos,

MAC
  #4 (permalink)  
Antiguo 03/05/2004, 03:04
Ex Colaborador
 
Fecha de Ingreso: junio-2002
Mensajes: 9.091
Antigüedad: 15 años, 6 meses
Puntos: 16
Bueno, si haces un echo de ambas formas veras las cadenas generadas. Y veras que faltan las ' inicial del primer elemento y final del ultimo elemento.

Saludos.
__________________
Josemi

Aprendiz de mucho, maestro de poco.
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 13:55.