Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

 
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 31-08-2004
sostro sostro is offline
Miembro
 
Registrado: ago 2004
Posts: 24
Poder: 0
sostro Va por buen camino
Question ADO: Error al ejecutar una consulta repetidamente

Hola a todos. Antes de nada agradeceros vuestro tiempo por leer este mensaje.

Entrando en materia, tengo una BD en acces, conecto en delphi 5 a traves de los componentes ADO y el error al que soy incapaz de dar con la solución consiste en lo siguiente; de un bucle for llamo en cada iteración a la siguiete consulta:


Procedure TMDatos.LeerRegistroPreguntaEspecialidad(Id_Pregunta:Integer);
begin
{Cerrar Query}
MDatos.ADOQuery2.Close;
With MDatos.ADOQuery2 do
begin
SQL.Clear;
SQL.Add('Select * from Pregunta_Especialidad Where Id_Pregunta=:
MiId_Pregunta');
Parameters.ParamValues['MiId_Pregunta']:=Id_Pregunta;
Open;
end;
end;

Esta consulta funciona perfectamente la primera vez que es llamada desde el bucle for; el problema reside en que en la segunda vez que es llamada, salta el error, que aparte de informar que ha levantado una excepción dice lo siguiente : "El valor de EOF o BOF es True, o el actual registro se eliminó; la operación solicitada requiere un registro actual".
En concreto el error salta en la linea donde cierro el ADOQuery2 (MDatos.ADOQuery2.Close.
La lectura de los datos de la consulta la hago desde la unit que llama a esta función (donde se está ajecutando el bucle for, comentado anteriormente)

Agradezco vuestro tiempo y saber....
Un saludo y gracias.
Responder Con Cita
 



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 12:42:42.


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