Foros del Web » Programando para Internet » PHP »

ultimo dato en bd

Estas en el tema de ultimo dato en bd en el foro de PHP en Foros del Web. como puedo saber por medio de un campo "id" (autoincrementable) cual es el numero total de entradas en una bd? o sea, el valor de ...
  #1 (permalink)  
Antiguo 20/08/2007, 13:32
Avatar de Nox
Nox
 
Fecha de Ingreso: diciembre-2004
Ubicación: Viña del Mar
Mensajes: 72
Antigüedad: 19 años, 3 meses
Puntos: 1
ultimo dato en bd

como puedo saber por medio de un campo "id" (autoincrementable) cual es el numero total de entradas en una bd? o sea, el valor de id de la ultima entrada en la bd...

__________________
todo es serio y ordenado, todo es racional y programado, precisamente porque todo es falso e ilusorio
  #2 (permalink)  
Antiguo 20/08/2007, 13:39
Avatar de pzin
Moderata 😈
 
Fecha de Ingreso: julio-2002
Ubicación: Islas Canarias
Mensajes: 10.488
Antigüedad: 21 años, 8 meses
Puntos: 2114
Re: ultimo dato en bd

Hola Nox.

Puedes saberlo usando mysql_insert_id().

Sería algo parecido a esto:
Código PHP:
$ultimoID mysql_insert_id($conexion); 
  #3 (permalink)  
Antiguo 20/08/2007, 13:44
Avatar de gerson  
Fecha de Ingreso: febrero-2005
Ubicación: Lima
Mensajes: 481
Antigüedad: 19 años, 2 meses
Puntos: 4
Re: ultimo dato en bd

Hola Nox pues son dos cosas distintas las que pides, por un lado el numero total de registros de una determinada tabla y por el otro la ultima entrada de registro en dicha tabla.

-Ahora bien para el primer caso seria necesario la siguiente consulta:

SELECT COUNT(id) FROM tabla

-En el segundo caso:

SELECT id FROM tabla ORDER BY id DESC LIMIT 0,1

y otra opcion seria la q te platena Bonez

Saludos
__________________


Última edición por gerson; 20/08/2007 a las 13:51
  #4 (permalink)  
Antiguo 20/08/2007, 13:56
Avatar de Nox
Nox
 
Fecha de Ingreso: diciembre-2004
Ubicación: Viña del Mar
Mensajes: 72
Antigüedad: 19 años, 3 meses
Puntos: 1
Re: ultimo dato en bd

en el caso de ser como lo dice bonez... la variable $conexion.. como deberia ser?

y en el caso de usar " SELECT COUNT(id) FROM tabla ", como tendria q escribir la variable que me de el numero final?
__________________
todo es serio y ordenado, todo es racional y programado, precisamente porque todo es falso e ilusorio
  #5 (permalink)  
Antiguo 20/08/2007, 14:13
Avatar de Nox
Nox
 
Fecha de Ingreso: diciembre-2004
Ubicación: Viña del Mar
Mensajes: 72
Antigüedad: 19 años, 3 meses
Puntos: 1
Re: ultimo dato en bd

porfavor necesito una respuesta luego
__________________
todo es serio y ordenado, todo es racional y programado, precisamente porque todo es falso e ilusorio
  #6 (permalink)  
Antiguo 20/08/2007, 14:43
Avatar de gerson  
Fecha de Ingreso: febrero-2005
Ubicación: Lima
Mensajes: 481
Antigüedad: 19 años, 2 meses
Puntos: 4
Re: ultimo dato en bd

Pues para el caso:

Código PHP:
$ultimoID mysql_insert_id($conexion); 


No habría mayor problema puesto que "$conexion" hace referencia a la conexión de la db y también es opcional, lo cual quiere decir que tomará siempre la última conexión y llamada INSERT q se generó.

Con respecto a la consulta:

Código PHP:
$resul mysql_query(" SELECT COUNT(id) FROM tabla");
echo 
mysql_result($resul,0); 

Saludos
__________________

  #7 (permalink)  
Antiguo 20/08/2007, 14:44
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Re: ultimo dato en bd

El parametro $conexion para el mysql_insert_id() es opcional puedes dejarlo en limpio:
Código PHP:
$ultimoID mysql_last_insertid(); 
Saludos.
  #8 (permalink)  
Antiguo 20/08/2007, 20:09
Avatar de shakaran  
Fecha de Ingreso: agosto-2005
Ubicación: España - Ciudad Real
Mensajes: 374
Antigüedad: 18 años, 8 meses
Puntos: 7
Re: ultimo dato en bd

GatorV en el manual de php no me aparece mysql_last_insertid() seguro que existe?

Código PHP:
$resul mysql_query(" SELECT COUNT(id) FROM tabla");
echo 
mysql_result($resul,0); 
Eso es muy lento, si quieres obtener realmente un indice(el total de filas) muy rapidamente la mejor manera es esta:
Código PHP:
$temp mysql_query("SELECT SQL_CALC_FOUND_ROWS * FROM table");
        
$result mysql_query("SELECT FOUND_ROWS()");
        
$total mysql_fetch_row($result); 
Otra cosa es que quieras obtener el ultimo indice insertado, entonces mysql_insert_id() es tu funcion ;)
__________________
Quijost Backend Engineer - www.quijost.com - Hosting rápido, eficiente y profesional
Blog: www.shakaran.net
  #9 (permalink)  
Antiguo 20/08/2007, 20:12
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Re: ultimo dato en bd

Tienes razon es mysql_insert_id.

Saludos.
  #10 (permalink)  
Antiguo 21/08/2007, 13:43
Avatar de Nox
Nox
 
Fecha de Ingreso: diciembre-2004
Ubicación: Viña del Mar
Mensajes: 72
Antigüedad: 19 años, 3 meses
Puntos: 1
Re: ultimo dato en bd

me funciono, muchas gracias =)
pero ahora tengo otro dilema... tengo varios meses en la bd... y cada entrada puede tener un mes, el problema es que tengo varias entradas con el mismo mes, y cuando quiero hacer una lista de los meses se repite el mes por cada entrada q contiene ese mes... como puedo hacer q solo se vea una lista de los meses? (o sea q se vea solo una vez el mes en vez de x veces)
__________________
todo es serio y ordenado, todo es racional y programado, precisamente porque todo es falso e ilusorio
  #11 (permalink)  
Antiguo 21/08/2007, 14:05
Avatar de ferbux  
Fecha de Ingreso: mayo-2007
Ubicación: por ahí intentado ayudar
Mensajes: 823
Antigüedad: 16 años, 11 meses
Puntos: 6
Re: ultimo dato en bd

Hola puedes hacerlo usando DISTINCT, algo mas o menos así:

$sel="select distintc mes from tu tabla";

salu2
__________________
"Eres grande por que caminas entre gigantes"
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:14.