Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Problema con mi codigo PHP / MYSQL.

Estas en el tema de Problema con mi codigo PHP / MYSQL. en el foro de PHP en Foros del Web. Hola. Tengo un problema con mi script php. Estoy desarrollando una aplicación de mensajería instantánea para Android. Uso HTTP como conexión entre el servidor y ...
  #1 (permalink)  
Antiguo 28/08/2013, 09:35
 
Fecha de Ingreso: agosto-2013
Mensajes: 18
Antigüedad: 10 años, 7 meses
Puntos: 1
Problema con mi codigo PHP / MYSQL.

Hola. Tengo un problema con mi script php.

Estoy desarrollando una aplicación de mensajería instantánea para Android. Uso HTTP como conexión entre el servidor y el teléfono.

En la base de datos tengo la siguientes tablas: happy_app_msg y happy_users. En la tabla happy_app_msg, almaceno los mensajes enviados entre los usuarios. y en happy_users los usuarios. Lo que quiero hacer es que mire todas las filas de happy_users, y con el campo nick de cada fila (algo así como un foreach) que obtenga el valor readed de la tabla happy_app_msg. No se si me he explicado.


Resumiendo quiero conseguir un valor de cada fila de una tabla y con ese valor conseguir otro asociado en otra tabla.

Este es el código que tengo hasta ahora que no me funciona. No me devuelve error, pero tampoco funciona como yo quiero.

Tal vez sea un poco raro programando... Lo he comentado lo mejor posible.


Código:
	if(checkUsername($COMANDO[1], $COMANDO[2])){ // esto verifica si el usuario es correcto.
	
		echo'04'; // Esto sirve solo para la aplicacion...
		$QUERY = mysql_query("SELECT nick FROM happy_users"); // Aqui, consigo todas las filas de la tabla happy users.
		
		foreach ($row[0] = mysql_fetch_assoc($QUERY) as $NICK) { // El foreach no va...
// Imaginate que $NICK (definido en el foreach) nos devueve el valor nick de una fila de happy_users.
		
			if($NICK == getUsername($COMANDO[1])){ // Verificamos que ese valor no seamos nosotros mismos
			} else {// chapuza...
				echo '*'; // Separador entre los otros readed del foreach
				
    			$QUERY2 = mysql_query("SELECT readed FROM happy_app_msg WHERE 'de' = '".$NICK."' 'hasta' = '".getUsername($COMANDO[1])."' LIMIT 1");// y luego aqui, intento conseguir el valor readed de la tabla happy_app_msg con $NICK y con getUsername($COMANDO[1]); que ese seria el nombre de usuario estaria usando la app.
				
				$READED = mysql_fetch_row($QUERY2); // con un mysql fech row
				if($READED[0] == 0){ // Si el valor es 0 devuelvo a la app el valor.. 85 etc...
					echo '85';
				}
				
				if($READED[0] == 1){
					echo '84';
				}
				
				if($READED[0] == 2){
					echo '83';
				}
				$QUERY2 = ''; // Y esto lo he puesto asi despues para evitar confusiones.
					
			}
		}
	} else {
		echo '00'; // Si la pass y el email no coinciden acceso denegado y devuelvo a la app el valor 00 que significa AUTH ERROR.
		exit;
	}

Muchas gracias!
  #2 (permalink)  
Antiguo 28/08/2013, 09:42
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problema con mi codigo PHP / MYSQL.

Yo aquí veo graves errores de sintaxis:
Código PHP:
$QUERY2 mysql_query("SELECT readed FROM happy_app_msg WHERE 'de' = '".$NICK."' 'hasta' = '".getUsername($COMANDO[1])."' LIMIT 1"); 
1. Los nombres de columna en la BD deben ir sin comillas pues no son cadenas de texto
2. Después entre ambas condiciones te hace falta un operador lógico AND/OR para tu caso
3. No depuras tus consultas, ¿así cómo esperas saber si ocurre un error? (adivinar no se puede)

Código PHP:
Ver original
  1. // código depurado
  2. $SQL2 = "SELECT readed FROM happy_app_msg WHERE de = '".$NICK."' AND hasta = '".getUsername($COMANDO[1])."' LIMIT 1";
  3. $QUERY2 = mysql_query($SQL2) or die('Error: ' . mysql_error() . '; SQL= ' . $SQL2);

¿Se entiende?
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 28/08/2013, 09:55
 
Fecha de Ingreso: agosto-2013
Mensajes: 18
Antigüedad: 10 años, 7 meses
Puntos: 1
Respuesta: Problema con mi codigo PHP / MYSQL.

Muchas gracias, pero... El codigo aun no me funciona. Creo que es el foreach. QUiero que cada fila de la tabla, ejecute el codigo que me as dado.

Muchas gracias.
  #4 (permalink)  
Antiguo 28/08/2013, 10:01
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problema con mi codigo PHP / MYSQL.

Puede ser, ¿pero entonces qué estás esperando para depurar?

Ahí también está mal tu código pues.
Código PHP:
Ver original
  1. // MAL
  2. foreach ($row[0] = mysql_fetch_assoc($QUERY) as $NICK)
  3.  
  4. // BIEN
  5. while ($row = mysql_fetch_assoc($QUERY)) {
  6.   $NICK = $row['columna_del_nick'];
  7. }

Eso de extraer datos de la BD y recorrerlos ya deberías saberlo hacer, es básico.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #5 (permalink)  
Antiguo 28/08/2013, 10:15
 
Fecha de Ingreso: agosto-2013
Mensajes: 18
Antigüedad: 10 años, 7 meses
Puntos: 1
Respuesta: Problema con mi codigo PHP / MYSQL.

Lo estoy probando... Tiene toda la pinta de que valla. Muchas gracias. Se que a estas altura ya debería saber eso... Muchas gracias.

Si funciona comento y marco tema como solucionado.
  #6 (permalink)  
Antiguo 28/08/2013, 10:29
 
Fecha de Ingreso: agosto-2013
Mensajes: 18
Antigüedad: 10 años, 7 meses
Puntos: 1
Respuesta: Problema con mi codigo PHP / MYSQL.

Perfecto, funciona. Solo una cosa, también ya se que es básico...

Un ! significa not en un if. no?
Pues quiero hacer algo como:
Código:
if(!$NICK == getUsername($COMANDO[1])){

// LO QUE SEA

}
Y no me va me hace cosas raras. Entonces ago esto:
Código:
if($NICK == getUsername($COMANDO[1])){ } else {

// LO QUE SEA

}
Que es lo que hago mal en el primer código?
  #7 (permalink)  
Antiguo 28/08/2013, 10:39
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problema con mi codigo PHP / MYSQL.

Claro, el ! es un not, negación pues.

El asunto es que tu condición es ambigua, pues el ! cancela el valor de la variable que le sigue y por ende no se compara como tienes en mente.

Así que en teoría parece como si se ejecutara así:
Código PHP:
Ver original
  1. if ( ( ! $foo ) == $bar)

Para evitar la ambigüedad puedes agrupar la comparación entre paréntesis.
Código PHP:
Ver original
  1. // MAL
  2. if ( ! $foo == $bar)
  3.  
  4. // BIEN
  5. if ( ! ($foo == $bar))

Con lo cual estarías negando la expresión completa, tal cual debe ser.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #8 (permalink)  
Antiguo 28/08/2013, 10:42
 
Fecha de Ingreso: agosto-2013
Mensajes: 18
Antigüedad: 10 años, 7 meses
Puntos: 1
Respuesta: Problema con mi codigo PHP / MYSQL.

Si, o directamente (me acabo de enterar) (CREO)
Código:
if ($foo !== $bar){
// LOQUESEA
}
Así, No?
  #9 (permalink)  
Antiguo 28/08/2013, 10:55
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problema con mi codigo PHP / MYSQL.

Claro, puede producir el mismo resultado.

Pero aún así no son idénticos, pues:
Cita:
if (! (x === y)) // significaría "que la expresión (x es exactamente igual a y) no sea verdadera"
if (! (x == y)) // significaría "que la expresión (x es igual a y) no sea verdadera"
if (x !== y) // significaría "que x no sea exactamente igual a y"
if (x != y) // significaría "que x no sea igual a y"
Te sugiero consultar en el manual oficial de PHP a propósito de los operadores para que te aclares.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #10 (permalink)  
Antiguo 28/08/2013, 10:55
 
Fecha de Ingreso: agosto-2013
Mensajes: 18
Antigüedad: 10 años, 7 meses
Puntos: 1
Respuesta: Problema con mi codigo PHP / MYSQL.

Vale, Perfecto! Lo acabo de comprobar muchas gracias. Marco como resuelto.

EDITO: php.net lo consulto muy a menudo, pero estas cosas de los operadores no lo suelo encontrar. De todas formas muchas gracias.

Última edición por xabihost; 28/08/2013 a las 10:58 Razón: Nuevo mensaje mientras escribia

Etiquetas: mysql, select, tabla, usuarios
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 22:29.