Foros del Web » Programando para Internet » PHP »

guardando el ultimo id

Estas en el tema de guardando el ultimo id en el foro de PHP en Foros del Web. Amigos. Hay alguna forma de saber el ID siguiente, desde el ultimo insert hecho, pero e aqui la salvedad. supongamos que el id generados son ...
  #1 (permalink)  
Antiguo 09/01/2008, 21:13
 
Fecha de Ingreso: abril-2005
Mensajes: 491
Antigüedad: 19 años
Puntos: 1
guardando el ultimo id

Amigos.

Hay alguna forma de saber el ID siguiente, desde el ultimo insert hecho, pero e aqui la salvedad.

supongamos que el id generados son
1
2
3
4

ocurrio algo mal y se borro el id: 4 y sobre eso se hace el select para el ultimo id.
que seria 3.

Ahora mi problema es que yo agrego unos datos sumando un 1 mas al ultimo id generado, es decir, si sigo el ejemplo el ultimo id es el 3, mas el 1 que le sumo son 4, guauu jaja....pero resulta que al proximo insert en la tabla, del 3 generara el 5 porque el 4 yo lo conto como id alguna vez creado...

entonces quedo con un 4 y un 5 y no me coinciden.

hay alguna forma de saber el siguiente id que viene aunque se hayan borrado id clave de la tabla como trate de explicarlo aca ?
  #2 (permalink)  
Antiguo 09/01/2008, 23:16
Avatar de Infernal  
Fecha de Ingreso: septiembre-2004
Ubicación: Tamaulipas, Mexico
Mensajes: 124
Antigüedad: 19 años, 7 meses
Puntos: 0
Re: guardando el ultimo id

Si usas mysql podrias utilizar SELECT last_insert_id() o SELECT MAX(id) o en php la funcion mysql_insert_id().

Saludos.
  #3 (permalink)  
Antiguo 10/01/2008, 04:45
 
Fecha de Ingreso: septiembre-2005
Mensajes: 80
Antigüedad: 18 años, 7 meses
Puntos: 0
Re: guardando el ultimo id

Cita:
Iniciado por Infernal Ver Mensaje
Si usas mysql podrias utilizar SELECT last_insert_id() o SELECT MAX(id) o en php la funcion mysql_insert_id().
Pero esas SQL son exactamente las que está ejecutando el amigo under_ground. Y eso no le resuelve el problema.

A mi entender NO es posible saber que ID le va a a tocar al proximo INSERT.
Por lo tanto la solucion seria hacer el INSERT, luego ejecutar SELECT last_insert_id() ( como dice Infernal ) y asi obtener el correcto ID.
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 21:21.