Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Tablas planas
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 14-01-2005
LOBO VELEZ LOBO VELEZ is offline
Registrado
 
Registrado: ene 2005
Posts: 5
Poder: 0
LOBO VELEZ Va por buen camino
reiniciar campo auto incremento

nesecito hayuda para reiniciar un campo de auto incremento de paradox
Responder Con Cita
  #2  
Antiguo 14-01-2005
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Código Delphi [-]
 procedure TForm1.Button1Click(Sender: TObject);
 begin
                        Table1.Close;
                      
 SetAutoInc('C:\Delphi\Prueba.db',StrtoInt(edit1.text));
                       Table1.Open;
 end;
 
 Procedure SetAutoInc(filename : string; Value : Longint);
                      var
                       mystream : tfilestream;
                      begin
                       mystream := tfilestream.create(filename,
                                   fmOpenWrite + fmShareExclusive);
                       try
                         mystream.Seek(73, soFromBeginning);
                         mystream.Writebuffer(Value, SizeOf(Value));
                       finally
                         mystream.Free;
                       end;
                      end;

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #3  
Antiguo 15-01-2005
LOBO VELEZ LOBO VELEZ is offline
Registrado
 
Registrado: ene 2005
Posts: 5
Poder: 0
LOBO VELEZ Va por buen camino
sigo con un problema

gracias pero tengo un problema con lo del auto incremento me mas¿rca un error en :setautoinc

procedure TForm1.Button1Click(Sender: TObject);
begin
Table1.Close;

SetAutoInc('C:\Delphi\Prueba.db',StrtoInt(edit1.text));
Table1.Open;
end;
Procedure SetAutoInc(filename : string; Value : Longint);
var
mystream : tfilestream;
begin
mystream := tfilestream.create(filename,
fmOpenWrite + fmShareExclusive);
try
mystream.Seek(73, soFromBeginning);
mystream.Writebuffer(Value, SizeOf(Value));
finally
mystream.Free;
end;
end;
Responder Con Cita
  #4  
Antiguo 15-01-2005
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por LOBO VELEZ
gracias pero tengo un problema con lo del auto incremento me mas¿rca un error en :setautoinc
Normalmente ayuda que indiques cuál es el error que te marca. Pero bueno, en este caso salta a la vista: no puedes llamar a SetAutoInc antes de haberlo declarado.

Por eso no es bueno copiar y pegar a ciegas los ejemplos que nos ponen

// Saludos
Responder Con Cita
  #5  
Antiguo 16-01-2005
LOBO VELEZ LOBO VELEZ is offline
Registrado
 
Registrado: ene 2005
Posts: 5
Poder: 0
LOBO VELEZ Va por buen camino
Exclamation Estoy Perdido Ayuda

Definitivamente No Entiendo Nececito Que Me Expliquen Como Hacerlo Paso A Paso Soy Nuevo No Programo Mucho Pero Quiero Aprender Como Se Declara Expliquenme Las Partes Algo Porfavor Gracias
Responder Con Cita
  #6  
Antiguo 16-01-2005
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Creo que estas un poco espeso, igual cuando te despejes ya lo solucionas, pero bueno.... ahí vá

Código Delphi [-]
form1 = class(Tform)
...
public

   Procedure SetAutoInc(filename : string; Value : Longint);

end;

implementation

Procedure Tform1.SetAutoInc(filename : string; Value : Longint);
begin
....
end;
Responder Con Cita
  #7  
Antiguo 16-01-2005
LOBO VELEZ LOBO VELEZ is offline
Registrado
 
Registrado: ene 2005
Posts: 5
Poder: 0
LOBO VELEZ Va por buen camino
Question no entiendo todavia bien

me marca un error en el public
Procedure SetAutoInc(filename : string; Value : Longint);
el errror dice:
[Error] MAIN.pas(21): Unsatisfied forward or external declaration: 'TForm1.SetAutoInc'
gracias.
Responder Con Cita
  #8  
Antiguo 16-01-2005
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Código Delphi [-]
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls;

  Procedure SetAutoInc(filename : string; Value : Longint);
type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.DFM}

procedure TForm1.Button1Click(Sender: TObject);
begin
Table1.Close;
SetAutoInc('D:\Pruebas\Prueba.db',0);
Table1.Open;
end;

 
Procedure SetAutoInc(filename : string; Value : Longint);
var
 mystream : tfilestream;
begin
 mystream := tfilestream.create(filename,
             fmOpenWrite + fmShareExclusive);
 try
   mystream.Seek(73, soFromBeginning);
   mystream.Writebuffer(Value, SizeOf(Value));
 finally
   mystream.Free;
 end;
end;
end.

Pon una tabla Paradox, en una carpeta la que sea, en mi ejemplo la tabla se llama Prueba.Db y está en la carpeta D:\Pruebas del disco duro Letra D:

Introduce algunos registros a mano, suponemos que tiene un campo autoincremento, borra todos los registros, todo esto desde el DatabaseDesktop, ahora introduce uno nuevo verás que el autoincremento sigue como iba por ejemplo con el número 20.

Ahora con el código que te he puesto si lo ejecutas, verás que la tabla cuando introduzcas nuevos registros empieza otra vez por 1.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 17:58:47.


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