Foros del Web » Programando para Internet » PHP »

Suconsulta en Mysql

Estas en el tema de Suconsulta en Mysql en el foro de PHP en Foros del Web. Hola! Necesito realizar una subconsulta en Mysql utilizando el operador IN. El caso es que como Mysql no soporta subconsulta tengo que utilizar el resultado ...
  #1 (permalink)  
Antiguo 07/05/2002, 12:40
 
Fecha de Ingreso: mayo-2002
Mensajes: 25
Antigüedad: 21 años, 11 meses
Puntos: 0
Suconsulta en Mysql

Hola!
Necesito realizar una subconsulta en Mysql utilizando el operador IN. El caso es que como Mysql no soporta subconsulta tengo que utilizar el resultado de otra consulta y no sé cómo hacerlo. Ahora mismo lo tengo de este modo pero me da errores.

Código:
  

$result=mysql_query("SELECT usuario FROM usuario WHERE nivel='7'",$link);
$resultat=mysql_fetch_array($result);

$result=mysql_query("SELECT numero,usuario,alta,descripcion FROM caso WHERE usuario IN '$resultat'",$link);
Intento utilizar el resultado de la consulta anterior para IN, pero no da resultado.

Alguien tiene una idea de cómo podría hacerlo?

Saludos.

  #2 (permalink)  
Antiguo 07/05/2002, 13:37
O_O
 
Fecha de Ingreso: enero-2002
Ubicación: Santiago - Chile
Mensajes: 34.417
Antigüedad: 22 años, 3 meses
Puntos: 129
Re: Suconsulta en Mysql

Para el parametro SQL IN .. el tipo de variables cual es? .. un string o un array?

Ten encuenta que el query (la consulta) la sacas a un array $resultat ..

Prueba a pasar el array a un string con la funcion implode()

Un saludo,
  #3 (permalink)  
Antiguo 07/05/2002, 15:26
Avatar de Webstudio
Colaborador
 
Fecha de Ingreso: noviembre-2001
Ubicación: 127.0.0.1
Mensajes: 3.499
Antigüedad: 22 años, 5 meses
Puntos: 69
Re: Suconsulta en Mysql

Sucede que lo estás haciendo mal.. deberías hacerlo asi :
<?
// obtenemos los usuarios de la base
$result=mysql_query("SELECT usuario FROM usuario WHERE nivel='7'",$link);
// Los metemos en un array
while($row = mysql_fetch_array($result)) $usuario[] = $row["usuario"];
//Separamos los usuarios por comas, para que el IN funcione
$usuario = implode(",", $usuario);

//Hacemos la consulta con el IN
$result=mysql_query("SELECT numero,usuario,alta,descripcion FROM caso WHERE usuario IN ('$usuario')",$link);
?>

Eso debería funcionar.




<hr><font size=2 face="verdana">- Pablo Daniel Rigazzi (Webstudio)
<font size=1 color="#333333">COORDINADOR PROYECTO REGIONALIZACION ARGENTINA
Visita <a href="http://www.web-studio.com.ar" target="_blank">Web Studio</a> - Tutoriales Photoshop</fo
  #4 (permalink)  
Antiguo 07/05/2002, 15:30
Avatar de BrujoNic
Super Moderador
 
Fecha de Ingreso: noviembre-2001
Ubicación: Costa Rica/Nicaragua
Mensajes: 16.935
Antigüedad: 22 años, 5 meses
Puntos: 655
Re: Suconsulta en Mysql

Bueno, me meti a MySQL y encontre esto que creo te puede servir.

<a href='ir.asp?http://www.mysql.com/doc/M/i/Missing_Sub-selects.html' target='_blank'>http://www.mysql.com/doc/M/i/Missing_Sub...</a>

Saludos.

<p align="center"><font color="#008080">Si la patria es pequeña, uno
grande la sueña... <u>Ruben Darío</u>
[/CODE]</p>
  #5 (permalink)  
Antiguo 07/05/2002, 16:22
 
Fecha de Ingreso: mayo-2002
Mensajes: 25
Antigüedad: 21 años, 11 meses
Puntos: 0
Re: Suconsulta en Mysql

Ok. Muchas gracias a todos, al final funcionó. ;)

Webestudio el código era correcto, solo había un problemilla con las comillas. He tenido que concatenar comillas para todas las entradas del array.

Por si os interesa finalmente funcionó así:
Código:
  
&lt;?
$result=mysql_query(&quot;SELECT usuario FROM usuario WHERE nivel='7'&quot;,$link);

while($row = mysql_fetch_array($result)) 
$usuario[]=&quot;\&quot;&quot;.$row[&quot;usuario&quot;].&quot;\&quot;&quot;;

$usuario = implode(&quot;,&quot;, $usuario);

$result=mysql_query(&quot;SELECT numero,usuario,alta,descripcion FROM caso WHERE usuario IN ($usuario)&quot;,$link);
?&gt;
Gracias de nuevo.
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 20:43.