Foros del Web » Programando para Internet » PHP »

¿SELECT dentro de un WHERE?

Estas en el tema de ¿SELECT dentro de un WHERE? en el foro de PHP en Foros del Web. Hola, no se si se puede hacer lo que intento pero creo que si, pero no se que falla: el error que me da es ...
  #1 (permalink)  
Antiguo 15/01/2014, 08:53
 
Fecha de Ingreso: enero-2008
Mensajes: 80
Antigüedad: 12 años, 5 meses
Puntos: 1
¿SELECT dentro de un WHERE?

Hola, no se si se puede hacer lo que intento pero creo que si, pero no se que falla:

el error que me da es este
mysqli_fetch_array() expects parameter 1 to be mysqli_result, boolean given in

Código:
$result = mysqli_query($conexion,"SELECT name FROM user WHERE id='(SELECT user_id FROM region_players WHERE region_id='$id')'");
Tambien he probado sin los parentesis, pero ni dea, ¿alguien me dice la sintaxis correcta?
  #2 (permalink)  
Antiguo 15/01/2014, 09:06
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 12 años, 6 meses
Puntos: 2656
Respuesta: ¿SELECT dentro de un WHERE?

No es tema de PHP, sino de Base de DAtos.
Trata de concentrarte en las características del problema antes de postear. Evitarás confusiones.

El fallo de "mysqli_fetch_array() expects parameter 1 to be mysqli_result, boolean given in" se debe a que lo que falla es la query, pero SQL no es PHP. No los confundas

Puntualmente, debe estar devolviendo un error de algún tipo desde MySQL, pero tu no lo estás mirando.
Código PHP:
$result mysqli_query($conexion,"SELECT name FROM user WHERE id='(SELECT user_id FROM region_players WHERE region_id='$id')'") or die("Error: ".mysqli_error($conexion)); 
Pero si miras con cuidado el problema es que no estás comparando el campo name.id con un valor numérico, sino con la cadena de texto "(SELECT user_id FROM region_players WHERE region_id='$id')":
Código SQL:
Ver original
  1. SELECT name FROM USER
  2. WHERE id='(SELECT user_id FROM region_players WHERE region_id='$id')'

O sea, estás poniendo cualquier cosa...

Código SQL:
Ver original
  1. SELECT `name` FROM `user`
  2. WHERE id IN (SELECT user_id FROM region_players WHERE region_id='$id')

o bien:

Código SQL:
Ver original
  1. SELECT `name` FROM `user` U INNER JOIN region_players R ON U.id=R.user_id
  2. WHERE region_id=$id

Esta segunda es más eficiente.

Ten cuidado con el "=" cuando compares con una subconsulta. Si ésta no devuelve un único registro te dará error.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)

Etiquetas: mysql, select
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 09:09.