Club Delphi  
    Paypal   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 Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

 
 
Herramientas Buscar en Tema Desplegado
  #3  
Antiguo 22-06-2006
joal joal is offline
Miembro
 
Registrado: jun 2006
Posts: 10
Poder: 0
joal Va por buen camino
Unhappy pues si esta activa, es lo curioso

Mejor incluyo el codigo, no vaya a ser que este haciendo una burrada de primaria (se vale montoneo, sirve que aprendo). Tengo un SQL por linea (algunas lineas las tengo como comentario, por lo que no las ejecuto), y siempre esta el CREATE previo al INSERT sobre dicha tabla.

Cita:
Código:
procedure Tfrm_inicializadorDB.bbtn_EjecutarClick(Sender: TObject);
var
  i: integer;
  str_query, str_table: string;
begin
  ibt_IBTransaction.StartTransaction;
  // Corro 1x1 los datos cargados previamente en un memo
  for i:= 0 to mem_Queries.Lines.Count do
    begin
    str_query:= Trim(mem_Queries.Lines.Strings[i]);
    if (Length(str_query) > 5) then
      begin
      if (Pos('CREATE TABLE ',str_query)>0) then
        begin
        // Es creacion de tabla, intento DROP sobre tabla anterior
        // identifico nombre de tabla
        str_table:= str_query;
        Delete(str_table,1,13);
        Delete(str_table,Pos(' ',str_table),Length(str_table));
        // intento hacer un drop
        ibq_IBQuery.SQL.Text:= 'DROP TABLE '+ str_table;
        try
          ibq_IBQuery.ExecSQL;
         finally end;
        // ahora si ejecuto la creacion de la tabla
        ibq_IBQuery.SQL.Text:= str_query;
        ibq_IBQuery.ExecSQL;
        ibt_IBTransaction.Commit;
       end
      else if (Pos('INSERT INTO ',str_query)>0) then
        begin
        // inserto en la tabla recien creada nuevos valores
        ibq_IBQuery.SQL.Text:= str_query;
        ibq_IBQuery.ExecSQL;
        ibt_IBTransaction.Commit;
       end;
      end;
    end; // for
  ibt_IBTransaction.Commit;
  // ibt_IBTransaction.Active:= false;
  ShowMessage('Base de datos inicializada');
  Close;
end;
gracias.

Última edición por joal fecha: 22-06-2006 a las 02:21:09. Razón: formateo
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
como puedo hacer correr mi apliccion en Intraweb ?? supermanpy Varios 0 05-06-2006 23:17:08
Como correr un archivo externo? fayala Firebird e Interbase 3 07-04-2005 03:56:00
No consigo hacer un INSERT akela Conexión con bases de datos 3 22-11-2004 00:46:42
Como correr multiples sentencias SQL en un Tquery al hacer un .ExecSQL/.open orfeo Conexión con bases de datos 6 27-03-2004 19:55:25
Quiero Saber como hacer que un boton se vea que esta siendo pulsado Julio César Varios 2 27-11-2003 18:34:11


La franja horaria es GMT +2. Ahora son las 03:44:08.


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
Copyright 1996-2007 Club Delphi