Foros del Web » Programando para Internet » PHP »

solo un numero de orden

Estas en el tema de solo un numero de orden en el foro de PHP en Foros del Web. nuevamente pido la ayuda de vosotros, tengo una db con varios campos dentro de ellos hay uno que es el orden que es un numero, ...
  #1 (permalink)  
Antiguo 24/08/2011, 01:31
Avatar de predacom  
Fecha de Ingreso: agosto-2003
Ubicación: arequipa-peru
Mensajes: 37
Antigüedad: 20 años, 8 meses
Puntos: 2
solo un numero de orden

nuevamente pido la ayuda de vosotros, tengo una db con varios campos dentro de ellos hay uno que es el orden que es un numero, lo que necesito es hacer lo siguiente:
si tengo estos numeros de orden:
1-2-3-4-5
y agrego un nuevo registro con un numero de orden 1 el resto se aumente en uno
es decir el resultado final seria:
1-2-3-4-5-6
es decir todos han corrido un numero mas el antes 1 ahora es 2 y el antes 2 ahora es 3 y asi sucesivamente
de igual manera si coloco un 3 de aqui en adelante el resto que recorra
espero me entiendan y me de alguna solucion, de antemano les agradesco la respuesta
__________________
Predacom Design Studio
www.predacom.net
  #2 (permalink)  
Antiguo 24/08/2011, 03:49
Avatar de vgonga1986  
Fecha de Ingreso: marzo-2008
Ubicación: País de Pandereta
Mensajes: 1.021
Antigüedad: 16 años, 1 mes
Puntos: 253
Respuesta: solo un numero de orden

Buenas, esto es más tema de SQL, pero bueno, no parece difícil, así que te doy la idea. Tendrás que hacer un update y luego un insert.

El update será para modificar todos los registros que tengan el número de orden igual o superior al que quieres insertar sumándoles uno. Si tenemos en la variable $order el orden del registro a insertar, sería algo así:
Código MySQL:
Ver original
  1. UPDATE Tabla SET orden = orden + 1 WHERE (orden >= $order);

Con esto ya tienes todos los registros actualizados, ahora sólo tienes que insertar el nuevo registro con el orden correspondiente:
Código PHP:
Ver original
  1. INSERT INTO Tabla (campos, orden, mas_campos) VALUES ($valores, $order, $mas_valores)

Un saludo.
__________________
¿Alguna pregunta, duda, acotación, nota, cuestión, reparo, comentario, demanda, crítica, interpretación, objeción, interrogante, discrepancia, observación, réplica, disquisición, apostilla o exégesis?

Etiquetas: numero, orden, registro
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 12:01.