Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-06-2012
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Query MySQL: ¿Por qué no funciona?

Me estoy volviendo loco; vale que es la primera vez que me enfrento a esta base de datos y seguro que estoy haciendo muchas cosas mal, pero así y todo me está volviendo loco.

Estoy usando con Builder 5 TDatabase, TSession y TQuery normales, de la paleta Data Access. Tengo este query:
Código:
Query->Close();
Query->SQL->Clear();
Query->SQL->Text = "SELECT num_socio, AES_DECRYPT(apellidos, 'Ju86Lfgsje340qW') apellidos, AES_DECRYPT(nombre, 'Ju86Lfgsje340qW') nombre, login_socio, activado FROM inscripciones WHERE activado IN ('A', 'P') ORDER BY apellidos, nombre, num_socio";
Query->Prepare();
Query->Open();
Se ejecuta sin dar ningún error pero al recorrerlo con este bucle para cargar un TListView:
Código:
for (; !Query->Eof; Query->Next())
{
     pItem = Lista->Items->Add();
     pItem->Caption = Query->FieldByName("apellidos")->AsString + ", " + Query->FieldByName("nombre")->AsString;
     pItem->SubItems->Add(Query->FieldByName("login_socio")->AsString);
     pItem->SubItems->Add(Query->FieldByName("num_socio")->AsInteger);
     pItem->SubItems->Add(Query->FieldByName("activado")->AsString);
}
sólo me reconoce el primer registro y en cuanto trato de leer el segundo me da un Acces violation error. He probado a cambiar la forma de recorrer la salida del query, pero lo ponga como lo ponga siempre da el mismo error y el query tiene 511 registros comprobados ejecutándolo en el shell de mysql.

Si en lugar de usar los componentes de Data Access uso los de la paleta ADO el bucle se recorre bien, pero al leer los datos de un registro cualquiera o cambiar las condiciones del query, poniendo por ejemplo WHERE activado = 'S' me sale el mensaje de El valor de BOF o EOF es True,o el actual registro se eliminó.

De verdad, ya no sé que hacer para que se ejecute bien el query. Cualquier ayuda es bien recibida.
Responder Con Cita
  #2  
Antiguo 26-06-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.043
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Me suena a un 'bug' que salía exactamente ese error, pero no recuerdo bien porque fue hace años, ¿componentes ADO?.
Responder Con Cita
  #3  
Antiguo 27-06-2012
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Ese código lo he probado con componentes normlaes, y me da el error que indico, y con componentes ADO y entonces pasa lo que indico al final del mensaje.
Responder Con Cita
  #4  
Antiguo 27-06-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.043
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
No conozco las distintas versiones de Builder, pero supongo que la que estás usando es contemporánea de delphi 5, más o menos.
En esa época, los componentes ADO tenían un bug que provocaban ese mensaje de error, sacaron un "parche/update" que lo solucionaba, además de otros arreglos.
Tengo una versión que es para Delphi, pero supongo que servirá igual para Builder, aquí está, por si te sirve.
Responder Con Cita
  #5  
Antiguo 27-06-2012
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Gracias. Porbaré y ya te diré como me ha ido.
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
problema con comillas en query LINUX , pero funciona en windows. JuanErasmo MySQL 2 12-05-2010 01:10:54
Query Access no funciona con ADO Delfino Conexión con bases de datos 6 15-06-2007 11:05:44
como funciona el dac for mysql zanyodark SQL 7 01-05-2007 20:08:05
OPENROWSET Funciona en MySQL? Alexander Conexión con bases de datos 0 12-02-2007 23:29:08
autorefresh no funciona en query y dbgrid ilichhernandez Conexión con bases de datos 6 08-11-2005 19:32:00


La franja horaria es GMT +2. Ahora son las 04:17:25.


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