![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
Ok. Aquí te pongo un ejemplo completo, listo para compilar. Incluye un archivo entradas.sql para que hagas pruebas con una versión reducida de tu tabla. Puedes introducir los datos en una base de prueba, por ejemplo la base test que ya se incluye con mysql:
Código:
mysql -uroot -p test < entradas.sql No hay necesidad de que tu llave primaria incluya los campos ID y FOLIO. Dado que ID es autonumérico, lo mejor es dejarlo sólo a éste como llave primaria. // Saludos |
|
#2
|
|||
|
|||
|
muchas gracias amigo si me funciona al 100, ya tenia tiempo batallando con esto de nuevo muchas gracias por el tiempo que te tomaste en esto
|
|
#3
|
||||
|
||||
|
¡Qué bueno que te funciona! Pero también es importante que compares con lo que estabas haciendo para que entiendas dónde estaba el problema.
// Saludos |
|
#4
|
|||
|
|||
|
claro que si estyo fijandome en todo lo que me estaba fallando aunque con este que me mandaste no me deja agregar mas de 2 registros al dbgrid, agrego uno y bien pero en el segundo me marca 'key violation'
|
|
#5
|
||||
|
||||
|
Cita:
PRIMARY KEY (`folio`,`id`)
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#6
|
||||
|
||||
|
Sí. El problema es este:
Al ser un campo autoincremental, el valor lo establece el servidor, pero dicho valor no puede conocerse hasta que no se haga un ApplyUpdates para mandar los cambios a la base de datos y un Refresh para recuperar los nuevos valores (los autoincrementales) desde la base. Como no estamos indicando ningún valor para ese campo, todos los registros nuevos toman el valor NULL y, claro, no puede haber dos registros con el mismo valor para una llave primaria. De ahí que falle al insertar el segundo registro. La solución está en este artículo de Embarcadero, pero la resumo aquí. 1. Hay que proporcionar un valor adecuado al campo autoincremental. Esto podemos hacerlo en el evento OnNewRecord del ClientDataSet:
Aquí, AutoId es una variable entera que inicializamos a -1 al momento de abrir el ClientDataSet. Así, los nuevos registros tomarán valores negativos: -1, -2, -3, etc. 2. Cada vez que hagamos el ApplyUpdates, debemos reiniciar esta variable y llamar al método Refresh:
3. Por último, tal como indica el artículo al final, debemos indicar que no se actualice el campo autoincremental, para que así los valors realmente sean los que asigna el servidor y no los nuestros negativos. Esto podemos hacerlo en el evento AfterOpen del dataset fuente (el MyQuery en nuestro caso):
// Saludos |
|
#7
|
|||
|
|||
|
sabes que me sale un error en cuanto ejecuto el programa que dice 'query: field ''id' not found'
|
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Actualizar estructura de base de datos sin perder datos | ManuelPerez | Firebird e Interbase | 8 | 20-10-2010 02:41:19 |
| Actualizar una base de datos desde un servidor remoto | zvf | MySQL | 1 | 22-06-2006 22:21:26 |
| Actualizar tabla buscando desde un dbgrid | judit25 | Conexión con bases de datos | 7 | 19-05-2006 16:08:57 |
| Actualizar una base de datos desde un formulario | federiconqn21 | Varios | 1 | 14-12-2005 16:43:23 |
| Actualizar la Base de Datos. | ramirezjl7 | Firebird e Interbase | 4 | 04-01-2005 08:44:51 |
|