Foros del Web » Programando para Internet » PHP »

generar automaticamente un id en web php

Estas en el tema de generar automaticamente un id en web php en el foro de PHP en Foros del Web. Hola buenas, necesitaria ayuda con un problema que tengo a la hora de generar id de usuario automaticamente en mi web cuando la gente se ...
  #1 (permalink)  
Antiguo 11/09/2012, 18:55
 
Fecha de Ingreso: septiembre-2012
Ubicación: Pontevedra
Mensajes: 48
Antigüedad: 11 años, 7 meses
Puntos: 2
generar automaticamente un id en web php

Hola buenas, necesitaria ayuda con un problema que tengo a la hora de generar id de usuario automaticamente en mi web cuando la gente se registra.

Actualmente lo que hace es recoger el id mas alto registrado de la base de datos, sumarle 1, y almacenarlo.

Pero eso ha planteado un problema cuando varias personas se registran a la vez...

Alguna idea de como resolverlo?

Gracias de antemano.
  #2 (permalink)  
Antiguo 11/09/2012, 19:07
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
Respuesta: generar automaticamente un id en web php

Normalmente se especifica en la base de datos que sea un campo autoincrementable. Así, al insertar un registro nuevo, no tienes que especificar ninguna ID, y la base de datos calcula de forma autónoma cual es la siguiente ID y la añade al registro.
  #3 (permalink)  
Antiguo 12/09/2012, 15:57
 
Fecha de Ingreso: septiembre-2012
Ubicación: Pontevedra
Mensajes: 48
Antigüedad: 11 años, 7 meses
Puntos: 2
Respuesta: generar automaticamente un id en web php

el problema es que no es mi proyecto ni mi base de datos, trabajo sobre una base echa por otra gente con una base de datos ya creada con literalmente millones de registros en las tablas.

Los tios saben que esta fatal echa, pero es lo que tienen y no quieren cambiarlo.

El id de usuario es un integer normal, de ahi que tenga que crear yo el algoritmo.

Pense en contabilizar el numero de sesiones abiertas, en la web descontar las registradas y incrementar el id en funcion del numero de sesiones que haya abiertas cuando tu ingreses, pero el problema de eso es que si hay (por ejemplo) 100 sesiones abiertas no registradas de las cuales solo se registra la 96 el nuevo id sera id antiguo+96 por lo que perderemos otros 95 id poren medio o tendriamos que complicar aun mas el algoritmo para que leyera ids no asignados, pero tampoco les hace mucha gracia por que quieren que el id del alumno corresponda mas o menos a la antiguedad.

Mas opciones? xD
  #4 (permalink)  
Antiguo 12/09/2012, 16:13
Avatar de memoadian
Colaborador
 
Fecha de Ingreso: junio-2009
Ubicación: <?php echo 'México'?>
Mensajes: 3.696
Antigüedad: 14 años, 10 meses
Puntos: 641
Respuesta: generar automaticamente un id en web php

No pues es que es una tonteria, la verdad el que hizo esa bd deberia pagar por daños y perjuicios, creo que te sería más facil, cambiar el tipo de campo y asignarles un id autoincrementable a cada alumno de nuevo, que estar buscando panaceas momentaneas.
  #5 (permalink)  
Antiguo 13/09/2012, 05:59
 
Fecha de Ingreso: septiembre-2012
Ubicación: Pontevedra
Mensajes: 48
Antigüedad: 11 años, 7 meses
Puntos: 2
Respuesta: generar automaticamente un id en web php

Trabajando por cuenta ajena tu le dices eso al comprador y lo que el oye es....

No tengo ni idea de como hacerlo, asi que quiero cambiartelo todo y cobrarte mas.
  #6 (permalink)  
Antiguo 13/09/2012, 06:46
Avatar de memoadian
Colaborador
 
Fecha de Ingreso: junio-2009
Ubicación: <?php echo 'México'?>
Mensajes: 3.696
Antigüedad: 14 años, 10 meses
Puntos: 641
Respuesta: generar automaticamente un id en web php

Cita:
Iniciado por barbel Ver Mensaje
Trabajando por cuenta ajena tu le dices eso al comprador y lo que el oye es....

No tengo ni idea de como hacerlo, asi que quiero cambiartelo todo y cobrarte mas.
No me refiero a que lo cambies todo, aunque nadie podría culparte por eso, si le explicas lo que pasa ya el decidirá.

Etiquetas: automaticamente, 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 04:12.