![]() |
error al ejectuar query dentro de beforepost
Hola a todos,
Estoy desarrollando una aplicación con ADO y ACCESS, y tengo una tabla TADOTable ("tabla") que tiene un autoincremental como PK, y un campo numérico ("código") como código significativo para los usuarios. Este código significativo tiene que ser continuo (sucesivo sin huecos), y en la gestión de esta continuidad es donde estoy encontrando los problemas. En el evento Beforepost de la tabla principal, intento hacer un "Select MAX(codigo) FROM tabla" con un TADOQuery para sacar el último código introducido, y guardarlo en el campo "código", y lo que obtengo es un bonito error de esta guisa... "[Microsoft][Controlador ODBC Microsoft Access] Error de sintaxis en la clausula FROM". Obviamente este error no tiene sentido, porque la tabla de la clausula from existe. Desde otros eventos de la tabla como "onposterror" y "afterpost" también falla... sin embargo desde fuera de los eventos de la tabla funciona perfectamente. Me imagino que tiene que ser algo relacionado con bloqueos, o con hacer una query sobre una tabla en sus propios eventos, pero llevo dos días buscando información y no logro encontrar la manera de solventarlo. Alguna idea?? Muchas gracias por adelantado, John. |
y por que no puede ser tipo autoincremental ese campo?
si no date una vuelta por el evento OnCalcFields de TTable. Tal ves ahi puedas. |
Cita:
Saludos. |
Respuesta...
Si lo que quieres es saber cual es el codigo nuevo que se insertó
lo que puedes hacer es una consulta con @@IDENTITY, te paso un ejemplo Código:
qryLocate.SQL.Clear;iNewID es una variable LongInt declarada anteriormente NewID es un campo ficticio que me arroja el @@IDENTITY, bah usando un alias. Esto lo ejecutas apenas hagas el insert en la tabla y no te preocupes por todos los eventos de ADO, es más si puedes evitarlos mejor aún. Bueno espero te sirva esto y Exitos!!! |
Hola a todos,
Antes de nada gracias por contestar, intentaré daros algo más de información. Cita:
No entiendo muy bien tu sugerencia sobre el oncalcfields, porque lo que quiero es asegurarme justo antes de insertar el registro que el código en continuo. John. |
Cita:
Código:
Function nextArmario() : integer;Saludos, John. |
Pues, es que el problema de los autoincrementales de access es que si se cancela la inserción corre núimero, así que aunque te agradezco tu propuesta, me temo que puedo usarla.
Estoy de acuerdo contigo sobre los eventos ADO, me temo que tienen algo que ver en este tema. Saludos, John. Cita:
|
Intenta con eso a ver que resulta. Saludos. |
Autoincremental...
El problema en Access con los autoincrementales es que hasta que no
hagas el post en la tabla no puedes saber el valor asignado, y otra cosa: A no ser que tu aplicación sea monousuaria no te sirve el MAX() +1, por lo que no sabes cual es el valor real y la unica manera es seleccionando el valor @@IDENTITY. El problema no es de ADO, simplemente te digo que no te hagas problemas con los eventos porque son muchos y me pasó hace un tiempo que la sucesión de eventos no siempre respetaba un orden especifico, [code]supongo se corrigió ese bug, pero por las dudas descarté todo. Por lo gral. cuando uso campos de tipo autoincremental lo hago cuando si o si inserto el registro y no cuando el usuario pueda cancelar la inserción. Sino lo que uso es una tabla con un registro donde estan los últimos valores asignados y a un valor de esos le sumo uno, o sea simulo un Autoinc y llevo yo el control y no Access. Te pego una función que la invoco cuando quiero insertar el registro Código:
function TData.GetKey( sField:string ) :LongInt;Algo así: Código:
Tabla.FieldByName( 'ID_PROVEEDOR' ).Value:=TData.GetKey('PROVEEDOR');Código:
procedure TData.SetKey( sField:string );Código:
TData.SetKey( 'PROVEEDOR'); |
| La franja horaria es GMT +2. Ahora son las 13:36:07. |
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