Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > C++ Builder
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #21  
Antiguo 06-06-2007
LordSarevok LordSarevok is offline
Miembro
 
Registrado: abr 2007
Posts: 16
Poder: 0
LordSarevok Va por buen camino
Pensaba compartirla cuando estuviese bien, para que no quede un codigo que no funciona del todo bien, es que no necesito dos consultas para hacer una, si no tres, el count para saber si hay resultados, la consulta en si y esta la tengo que repetir para que ese maldito eof no este a true, pero bueno, ahi va xD.

Código:
TADODataSet * __fastcall Taux::consulta(AnsiString consulta,AnsiString consulta2)
//Consulta 1 es la consulta a realizar y consulta2 el count.
   {
     this->ADOConnection1->Connected=true;
     this->ADODataSet1->Connection=this->ADOConnection1;
     this->ADODataSet1->ConnectionString=this->ADOConnection1->ConnectionString;
     this->ADODataSet1->CommandText=consulta2;
     this->ADODataSet1->Active=true;
     this->ADODataSet1->First();
     if (this->ADODataSet1->FieldByName(this->ADODataSet1->FieldDefs->Items[0]->Name)->AsInteger>0)    
//si el count es >0
        {
           this->ADODataSet1->Active=false;
           this->ADODataSet1->CommandText=consulta;
           this->ADODataSet1->Active=true;
           //Hacemos la consulta y retornamos el DataSet para procesarlo
           return (ADODataSet1);
        }
     else //Si no, devolvemos un null y cerramos esta consulta.
        { 
           this->ADODataSet1->Close();
           return(NULL);
        }
   }
//---------------------------------------------------------------------
void __fastcall Taux::desconectar(TADODataSet *c)
   {
            WideString asd=c->CommandText; //Es necesario reasignar la consulta para que la repita.
            c->CommandText=asd;
            c->Active=true;
            c->Open(); //Esta es la 3º consulta a la que me refiero.
            c->Close();
   }
//------------------ Un ejemplo de Procesar la Consulta -----------
     TADODataSet *asd=aux->consulta("select * from...","select count(*) ....");
    if (asd!=NULL)
         {
            while (asd->Eof!=true)
              {
                 j++;
                 Tabla->Cells[0][j]=m->FieldByName("autonumerico")->AsInteger;
                 Tabla->Cells[1][j]=m->FieldByName("proveedor.nombre")->AsString;
                 ....
                 asd->Next();
              }
            aux->desconectar(asd);
Responder Con Cita
  #22  
Antiguo 13-06-2007
LordSarevok LordSarevok is offline
Miembro
 
Registrado: abr 2007
Posts: 16
Poder: 0
LordSarevok Va por buen camino
No se os ha ocurrido nada verdad? :/

Otra "pega" es que al ejecutar alguna insercion/update/delete no tengo mas remedio que meterle un sleep de un segundo porque si no al hacer un select nada mas escribir algo, no aparece en la consulta.

Última edición por LordSarevok fecha: 13-06-2007 a las 18:12:37.
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
Edit en TADODataSet scooterjgm Conexión con bases de datos 2 10-04-2006 09:46:36
Trabajando con TADODataset Novato Conexión con bases de datos 2 08-10-2005 23:57:27
Duda Delphius Varios 5 02-06-2005 07:40:29
TADODataSet VS TADOQuery Mauro.NET Conexión con bases de datos 1 24-05-2005 19:39:57
objeto TADODataSet Nidia H. Ochoa OOP 2 06-07-2004 22:48:12


La franja horaria es GMT +2. Ahora son las 16:25:32.


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