Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Max(ID_U) Error

Estas en el tema de Max(ID_U) Error en el foro de PHP en Foros del Web. Buenas a todos, necesito un poco de ayuda a ver si alguien me puede explicar por qué al intentar ejecutar esta consulta... mysqli_query($con,"select max(id_u) from ...
  #1 (permalink)  
Antiguo 10/02/2016, 15:35
 
Fecha de Ingreso: febrero-2016
Mensajes: 9
Antigüedad: 8 años, 2 meses
Puntos: 0
Max(ID_U) Error

Buenas a todos, necesito un poco de ayuda a ver si alguien me puede explicar por qué al intentar ejecutar esta consulta...

mysqli_query($con,"select max(id_u) from usuarios");

!ATENCIÓN! ESTOY HABLANDO ACERCA DE UNA CONSULTA DESDE UNA PÁGINA EN PHP.

no recibo ningún dato. He probado de muchas maneras sin éxito y me ha superado. ¿Algun consejo?

EDITO EL MENSAJE PARA DAR MÁS DETALLES.

Resulta que necesito conseguir la id del último usuario registrado (ya que es autoincremental) para de esta forma, un contador RANDOM solo pueda llegar hasta ese número más alto haciendo referencia a un usuario al azar.

Por ejemplo:

ID_u | Usuario
1 Pedro
2 Luis
3 Pablo
4 Alberto
5 Ricardo

Dispongo de esto: $numeroalazar=mt_rand(1,$max);

Lo que quiero es que me diga un número al azar entre 1 y 5 ya que si selecciona otro para el cual no existe un usuario creado no tendría sentido para mi objetivo. Realmente lo necesito para seleccionar un usuario con su ID_U aleatoriamente. Para ello he colocado la variable $max (número máximo de usuarios registrados).

Última edición por UnPicoleto; 10/02/2016 a las 15:49
  #2 (permalink)  
Antiguo 10/02/2016, 16:42
Avatar de quitos  
Fecha de Ingreso: junio-2004
Mensajes: 119
Antigüedad: 19 años, 10 meses
Puntos: 1
Respuesta: Max(ID_U) Error

Por que en tu sentencia de query van al reves los datos:


mysqli_query("select max(id_u) from usuarios",$con);



Prueba y me dices.
Saludos
  #3 (permalink)  
Antiguo 10/02/2016, 16:48
Avatar de quitos  
Fecha de Ingreso: junio-2004
Mensajes: 119
Antigüedad: 19 años, 10 meses
Puntos: 1
Respuesta: Max(ID_U) Error

Ammm y leyendo el final de su posteo, creo que vas a tener problemas en lograr lo que buscas con el algoritmo que estás utilizando.

Por Ej.

En éste momento de la tabla tienes 5 registros:

ID_u | Usuario
1 Pedro
2 Luis
3 Pablo
4 Alberto
5 Ricardo

Si en algún momento tu tabla cambia igual a 5 registros, pero diste de baja a un usuario:

ID_u | Usuario
1 Pedro
2 Luis
4 Alberto
5 Ricardo
6 Benito

El algoritmo que usas te va a dar un Random de 1 a 5, si te sale el 3, ya no te va a devolver nada.

Sugerencia: idea otra solución.
  #4 (permalink)  
Antiguo 10/02/2016, 16:59
 
Fecha de Ingreso: febrero-2016
Mensajes: 9
Antigüedad: 8 años, 2 meses
Puntos: 0
Respuesta: Max(ID_U) Error

Podría utilizar un bucle While con la consulta max(id_u) ?? Solo quiero tomar el valor y utilizarlo después. He probado a colocarlo asi:
mysqli_query("select max(id_u) from usuarios",$con);
Como puedo mostrarlo por pantalla para comprobar que funciona correctamente? Estoy demasiado acostumbrado a la utilización de bucles while...

MI IDEA:

$numeroalazar=mt_rand(1,5);
1 número minimo
5 numero maximo (Necesito el numero maximo de usuarios registrados)

Última edición por UnPicoleto; 10/02/2016 a las 17:07
  #5 (permalink)  
Antiguo 10/02/2016, 17:08
Avatar de chulifo  
Fecha de Ingreso: abril-2009
Ubicación: perdido en codigos del PHP, pero aprendo rapido!
Mensajes: 524
Antigüedad: 15 años
Puntos: 18
Respuesta: Max(ID_U) Error

Entiendo que deseas seleccionar un usuario al azar, entonces...

Por que no prueba arrojando los resultados en un Array y luego utlizas array_rand()

Si no es asi explica tu idea mejo por favor
__________________
Solo soy un simple fanático que mata el tiempo de la mejor manera.
  #6 (permalink)  
Antiguo 10/02/2016, 17:09
 
Fecha de Ingreso: febrero-2016
Mensajes: 9
Antigüedad: 8 años, 2 meses
Puntos: 0
Respuesta: Max(ID_U) Error

Parece una idea bastante buena, podrías decirme como puedo hacer algo así?
  #7 (permalink)  
Antiguo 10/02/2016, 17:15
Avatar de chulifo  
Fecha de Ingreso: abril-2009
Ubicación: perdido en codigos del PHP, pero aprendo rapido!
Mensajes: 524
Antigüedad: 15 años
Puntos: 18
Respuesta: Max(ID_U) Error

Cita:
Iniciado por UnPicoleto Ver Mensaje
Parece una idea bastante buena, podrías decirme como puedo hacer algo así?
Aqui encuentras algo sobre mysqli.query

y por aqui otro poco sobre fetch

ademas de consultar con el array_rand que ta te deje antes.


El manual trae buen información.
__________________
Solo soy un simple fanático que mata el tiempo de la mejor manera.
  #8 (permalink)  
Antiguo 10/02/2016, 17:30
 
Fecha de Ingreso: febrero-2016
Mensajes: 9
Antigüedad: 8 años, 2 meses
Puntos: 0
Respuesta: Max(ID_U) Error

[URL="http://imgur.com/YGNdmpL"]Imagen 1[/URL]

[URL="http://imgur.com/YIEtiSY"]Imagen 2[/URL]

Necesito urgentemente resolver esto, lo necesito para un proyecto.

No consigo que me dé ni un usuario al azar ni la ID_U más grande para utilizar el método

mt_rand(1,$idmasgrande)
  #9 (permalink)  
Antiguo 10/02/2016, 17:32
Avatar de quitos  
Fecha de Ingreso: junio-2004
Mensajes: 119
Antigüedad: 19 años, 10 meses
Puntos: 1
Respuesta: Max(ID_U) Error

De hecho la idea optima seria usar array_rand.

Haces tu consulta devolviendo solo los ID's

Los guardas en una variable en forma de array ($miArray[]=$consulta)

Y despues llamas el array_rand.

Y lixto, solo obtienes uno, y con eso sabes que vas a obtener el ID que si exista.
  #10 (permalink)  
Antiguo 10/02/2016, 18:00
 
Fecha de Ingreso: febrero-2016
Mensajes: 9
Antigüedad: 8 años, 2 meses
Puntos: 0
Respuesta: Max(ID_U) Error

$sqldatos=mysqli_query($con,"select id_u from usuarios order by id_u DESC");



while($miArray[]=$sqldatos){

echo array_rand($miArray);

}

De esta manera se me crea un bucle infinito, ¿Cómo puedo hacer para que solo obtenga un valor al azar?
  #11 (permalink)  
Antiguo 10/02/2016, 18:16
Avatar de quitos  
Fecha de Ingreso: junio-2004
Mensajes: 119
Antigüedad: 19 años, 10 meses
Puntos: 1
Respuesta: Max(ID_U) Error

Ammmm...

Practica más códigos de ejemplo de como hacer un ciclo while... !

--------------------------------------------

$sqldatos=mysqli_query("select id_u from usuarios order by id_u DESC");


$miArray= array();
foreach($sqldatos as $sqldatos){
$miArray[]=$sqldatos;
}

$idDelArray= array_rand($miArray);
echo $miArray[$idDelArray];
  #12 (permalink)  
Antiguo 10/02/2016, 18:20
Avatar de quitos  
Fecha de Ingreso: junio-2004
Mensajes: 119
Antigüedad: 19 años, 10 meses
Puntos: 1
Respuesta: Max(ID_U) Error

jajaja por cierto me faltó el fetch_row jajaja

Sorry, tambien ando en la chamba... !

---------------------------------------------

$losIds= mysqli_query("select id_u from usuarios order by id_u DESC");
$sqldatos= mysqli_fetch_row($losIds);

$miArray= array();
foreach($sqldatos as $sqldatos){
$miArray[]=$sqldatos;
}

$idDelArray= array_rand($miArray);
echo $miArray[$idDelArray];
  #13 (permalink)  
Antiguo 11/02/2016, 00:32
 
Fecha de Ingreso: noviembre-2003
Ubicación: Zaragoza, España
Mensajes: 1.257
Antigüedad: 20 años, 5 meses
Puntos: 154
Respuesta: Max(ID_U) Error

Hola UnPicoleto,

Si lo que necesitas es sacar un id_u al azar de tu tabla, no hace falta que te compliques tanto, con una consulta así lo resuelves:

Código MySQL:
Ver original
  1. SELECT id_u FROM usuarios ORDER BY RAND() LIMIT 1

Espero que te sirva.
  #14 (permalink)  
Antiguo 11/02/2016, 10:07
Avatar de quitos  
Fecha de Ingreso: junio-2004
Mensajes: 119
Antigüedad: 19 años, 10 meses
Puntos: 1
Respuesta: Max(ID_U) Error

Ha muy buena esa opción, no me la sabia..... :)

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