Foros del Web » Programando para Internet » PHP »

Problema con select y mostrar resultados

Estas en el tema de Problema con select y mostrar resultados en el foro de PHP en Foros del Web. Hola. Hace poco publiqué un tema sobre un problema que tenía mostrando resultados... Resuelto ese, tengo otro parecido, pero éste por más que le doy ...
  #1 (permalink)  
Antiguo 13/08/2009, 04:24
 
Fecha de Ingreso: julio-2009
Mensajes: 52
Antigüedad: 14 años, 9 meses
Puntos: 3
Problema con select y mostrar resultados

Hola. Hace poco publiqué un tema sobre un problema que tenía mostrando resultados... Resuelto ese, tengo otro parecido, pero éste por más que le doy las vueltas, no consigo encontrarle el fallo. El script en cuestión es éste:

Código PHP:
function muestraAmigos() {
    
    
// Instanciamos objeto de conexión con base de datos.
    
$c = new bd();
    
    
// Buscamos todos los usuarios que tengan el ID de nuestro usuario como amigo.
    
$amigos=mysql_query("SELECT amigos.us1,amigos.us2,usuarios_perfil.username,usuarios_perfil.id FROM amigos,usuarios_perfil WHERE usuarios_perfil.id != '".$_SESSION['id']."' && amigos.us1 = '".$_SESSION['id']."' || amigos.us2 = '".$_SESSION['id']."'");

    while(
$us=mysql_fetch_array($amigos)) {
        
$this->id_atacado=$us["id"];
        
$this->atacado=$us["username"];
        echo  
'<option value="'.$this->id_atacado.'">'.$this->atacado.'</option>';
        
    }

Luego, dentro de un SELECT instancio un objeto de la clase en la que está contenido éste método, y después llamo (con el objeto instanciado) a éste método. Hasta ahí todo correcto, sin problema. El problema viene a la hora de mostrar los registros, me muestra registros dobles y el propio registro del usuario. Es decir:
  • MiUsuario
  • Amigo1
  • Amigo1
  • Amigo2
  • Amigo2
  • Amigo3
  • Amigo3
  • Y asi sucesivamente

Varias dudas:
1- No sé por que me muestra mi usuario, si como primera condición le estoy diciendo que NO coja los registros cuya ID sea igual a mi sesión de usuario.
2- No sé por qué me muestra registros dobles, si sólo existe un registro dentro de la base de datos "amigos" que apunte hacia dicha ID.

En fin... Dudas de novato, ya que apenas llevo 1 mes programando en PHP, y algo más de 1 semana con POO en PHP. Agradezco su ayuda de antemano.

Saludos!!
  #2 (permalink)  
Antiguo 13/08/2009, 05:40
Avatar de emiliodeg  
Fecha de Ingreso: septiembre-2005
Ubicación: Córdoba
Mensajes: 1.830
Antigüedad: 18 años, 7 meses
Puntos: 55
Respuesta: Problema con select y mostrar resultados

pues hoy estas de buenas, pq solucionarlo es muy facil

sobre el final de tu sql agrega group by amigos.us1,amigos.us2,usuarios_perfil.username,usu arios_perfil.id

o agrupa por las columna q quieras q no se repita
__________________
Degiovanni Emilio
developtus.com
  #3 (permalink)  
Antiguo 13/08/2009, 05:56
 
Fecha de Ingreso: julio-2009
Mensajes: 52
Antigüedad: 14 años, 9 meses
Puntos: 3
Respuesta: Problema con select y mostrar resultados

EDITO

He probado a agrupar solo por nombre de usuario, y ahora me muestra sólo una vez cada registro. El problema viene ahora en que también me muestra mi usuario, cuando yo le estoy diciendo en el query que si el id es igual a mi sesión, que no me lo coja... Y la session corresponde con mi id (lo he comprobado).

Saludos.
  #4 (permalink)  
Antiguo 13/08/2009, 06:03
Avatar de emiliodeg  
Fecha de Ingreso: septiembre-2005
Ubicación: Córdoba
Mensajes: 1.830
Antigüedad: 18 años, 7 meses
Puntos: 55
Respuesta: Problema con select y mostrar resultados

revisa q datos tienes cargados en las tablas, utiliza alguna tabla con menos datos para facilitar la tarea

proba con agregar parentesis, me imagino q lo q queres es algo asi

usuarios_perfil.id != '".$_SESSION['id']."' && (amigos.us1 = '".$_SESSION['id']."' || amigos.us2 = '".$_SESSION['id'].")'

sino pasa de nuevo y lo revisamos
__________________
Degiovanni Emilio
developtus.com
  #5 (permalink)  
Antiguo 13/08/2009, 06:04
 
Fecha de Ingreso: julio-2009
Mensajes: 52
Antigüedad: 14 años, 9 meses
Puntos: 3
Respuesta: Problema con select y mostrar resultados

Oh!! Fantástico

Justo eso quería... Una cosa más que ya sé: Pueden usarse paréntesis en querys (ni se me había pasado por la cabeza...).

Mil gracias!!.

Saludos.
  #6 (permalink)  
Antiguo 13/08/2009, 06:08
Avatar de emiliodeg  
Fecha de Ingreso: septiembre-2005
Ubicación: Córdoba
Mensajes: 1.830
Antigüedad: 18 años, 7 meses
Puntos: 55
Respuesta: Problema con select y mostrar resultados

jejejej de nada
__________________
Degiovanni Emilio
developtus.com
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 08:30.