Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error Key violation al insertar nuevo registro en Paradox
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error Key violation al insertar nuevo registro en Paradox

Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error Key violation al insertar nuevo registro en Paradox Responder citando

Como comenté en otro post conseguí arreglar el error de Corrupt table/index header. Pero ahora, cuando intento insertar un registro en la tabla facturas.db, me aparece este error:

"Key violation".

Y no me deja insertar registros.

Le he pasado la utilidad que comentabas en el otro post "Borland TUtility DTUtil32" pero sigue dándome el mismo problema ¿a qué puede ser debido? ¿cómo lo arreglo?
MensajePublicado:
Jue May 08, 2008 6:39 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error Key violation al insertar nuevo registro en Parado Responder citando



Anuncios



varios escribió:
Como comenté en otro post conseguí arreglar el error de Corrupt table/index header. Pero ahora, cuando intento insertar un registro en la tabla facturas.db, me aparece este error:

"Key violation".

Y no me deja insertar registros.

Le he pasado la utilidad que comentabas en el otro post "Borland TUtility DTUtil32" pero sigue dándome el mismo problema ¿a qué puede ser debido? ¿cómo lo arreglo?


¿Utilizas autoincremento en el campo que es clave primaria/primary key de la tabla? Si es así el error aparece porque por algún corte eléctrico u otro motivo el acceso a la tabla, mientras se hacía una inserción, no se cerró correctamente, por lo que se te corrompieron los índices y, además, el contador del autoincremento no avanzó, con lo cual al intentar añadir un nuevo registro Paradox intenta asignarle un número al autoincremento que ya existe.

Para solucionar esto deberás seguir estos pasos:

1º Abre la tabla con Database Desktop, pulsa en "Table" - "Reestructure", te posicionas en el campo que tengas como clave primaria, con el asterisco "*", se lo quitas (para que no sea clave primaria), también le cambias el tipo de datos de Autoincremento (+) a Long Integer (I).
2º Añades un nuevo campo, con el nombre que quieras, de tipo de datos + (Autoincrement) y que sea clave primaria (*).
3º Marcas "Pack Table" y "Save".
4º Vuelves a acceder al menú "Table" - "Reestructure", eliminas el campo añadido anteriormente que es clave primaria y en el tuyo, el que era clave primaria y el que vale, le vuelves a cambiar el tipo de datos de I (Long Integer) a + (Autoincrement) y lo vuelves a poner como clave primaria (*).
5º Vuelves a marcar "Pack table" y pulsas en "Save".
6º Ahora añade un registro de prueba en la tabla utilizando Database Desktop y lo eliminas, vuelve a añadir otro para comprobar que el autoincremento funciona y lo vuelves a eliminar.

Con esto te debería funcionar. Existen otros métodos para solucionar este problema, como por ejemplo sólo cambiar el tipo de datos del campo que tienes como clave primaria / primary key por I (Long Integer) y pulsar en Save, luego vuelves a reestructurar y le vuelves a poner como tipo de datos + (autoincremento), con esto, a veces, es suficiente.
MensajePublicado:
Jue May 08, 2008 7:19 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A