Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Reordenar consecutivo (https://www.clubdelphi.com/foros/showthread.php?t=68408)

Vlady 11-06-2010 18:53:22

Reordenar consecutivo
 
Hola amigos del club delphi dento el siguiente problemilla quiero q en el momento de eliminar un registro de una tabla se reordene la llave primaria que es un campo incremental es decir por ejemplo tengo lo siguientes registros:

Código:

      id    nombres    apellidos
      334    LUIS          PEREZ
      335    CAMILO      MEDINA
      336    ARMANDO    BUITRAGO
      337    OMAR          RODIGUEZ

En el momento en que se elimine el registro 335 el campo ID que es PK de la tabla debe disminuir en 1. Quedando de esta forma
Código:

      id    nombres    apellidos
      334    LUIS          PEREZ
      335    ARMANDO    BUITRAGO
      336    OMAR          RODIGUEZ

Alguna sugerencia para este problemilla. Una forma que he pensado es esta:

Código SQL [-]
      WHILE (PRIMERO <= :ULTIMO) DO
      BEGIN
          UPDATE CLIENTE SET ID = :PRIMERO WHERE ID =   :PRIMERO + 1;
         PRIMERO = :PRIMERO + 1;
     END
donde PRIMERO es el registro que estoy borrando y ULTIMO es el ultimo registro de la tabla, el problema con este codigo es que no me permite borrar barrios registros a la vez. Espero que me puedan ayudar. Se me olvidaba trabajo con firebird 2.0 y DELPHI 7.

roman 11-06-2010 19:38:38

Pero, ¿para qué quieres hacer esto? En mi opinión es una complicación innecesaria y propensa a errores. ¿Qué pasa, por ejemplo, si tienes accesos simultáneos? Tus llaves se pueden hacer un desbarajuste.

Una llave primaria tendría que ser inamovible, sobre todo si es llave foránea en otras tablas.

// Saludos

Casimiro Noteví 11-06-2010 19:51:58

Absoluta y totalmente de acuerdo con Román, ¿qué ocurre ahora con los datos de facturas o de cualquier otra tabla (depende de tu programa) que estén relacionados con ese código?, le estarías asignado facturas a otros clientes!!!

Vlady 11-06-2010 22:34:22

Esto lo controlo con triggers para que no se facture a otros clientes, ademas lo debo hacer hacer para tener el consecutivo de los clientes.

Vlady 12-06-2010 00:12:22

ademas esto no es precisamente para una tabla de clientes, es que el ejemplo lo hice de esta forma, es para una tabla de pedidos y necesito conservar el consecutivo de cada pedido asi borren alguno en cualquier momento, luego renumerar el ID

Casimiro Noteví 12-06-2010 00:17:52

Pero, si por ejemplo, el pedido es del cliente 100 y borras el cliente 90. Tras la renumeración el cliente 100 ahora será el 99. Y el pedido que era del cliente 100 ahora quedará huérfano o pertenecerá al "nuevo" cliente 100, que antes era el 101.

De todas formas, debes buscar otra forma de hacer eso, no es nada factible, salvo que sea un campo más de la tabla, pero no la clave principal.

Vlady 12-06-2010 00:33:28

Casimiro Gracias por responder, pero te cuento que esto no es de una tabla de clientes es solo un ejemplo q se me ha ocurrido lo quiero hacer es con una tabla de Pedidos donde la PK no es foranea en ninguna otra tabla o q deseo es q en el momento de eliminar un pedido se reorganicen los numeros de pedidos.

Casimiro Noteví 12-06-2010 00:43:09

Pues tendrás que hacerlo con un bucle, por ejemplo, ordenas por nombre (por ejemplo) y luego lo vas recorriendo de principio a fin y le vas poniendo el código que toque.

Algo así:

Código:

query.close;
query.selectsql.text := 'select * from tbclientes order by apellidos, nombre';
query.open;
iNumero := 1;
while not query.eof do
begin
  query.edit;
  query.fieldbyname('codigo').asinteger := iNumero;
  query.post;
  query.next;
  inc( iNumero );
end;


Vlady 12-06-2010 01:14:51

Gracias casimiro pero de esta forma me salta que el ID ya existe y da error de primary key ya existe.

Casimiro Noteví 12-06-2010 01:29:18

Cita:

Empezado por Vlady (Mensaje 367069)
Gracias casimiro pero de esta forma me salta que el ID ya existe y da error de primary key ya existe.

Claro, porque debes saltarte los que ya existen con el código correcto. Prueba algo parecido a esto:

Código:

query.close;
query.selectsql.text := 'select * from tbclientes order by apellidos, nombre';
query.open;
iNumero := 1;
while not query.eof do
begin
  if query.fieldbyname('codigo').asinteger <> iNumero then
  begin
    query.edit;
    query.fieldbyname('codigo').asinteger := iNumero;
    query.post;
  end;
  query.next;
  inc( iNumero );
end;



La franja horaria es GMT +2. Ahora son las 21:25:32.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi