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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-08-2012
Avatar de martini002
martini002 martini002 is offline
Miembro
 
Registrado: may 2012
Ubicación: Puerto Ordaz - Venezuela
Posts: 175
Poder: 12
martini002 Va por buen camino
Error Sumando Columnas SQL

Saludos amigos, donde quiera que se encuentren.

En el siguiente codigo, podran darse cuenta que funciona
como un ciclo infinito, hasta que el usuario decida detener
el programa, basicamente lo que hacemos es agregar en una tabla temporal
algunos datos para visualizarlos en un grid, luego vaciamos esos datos
en nuevas tablas para el registro de facturas, y luego limpia la tabla temporal
para poder crear nuevas facturas.

El problema consiste en lo siguiente:
agregamos los articulos con el boton1 y luego cuando tengamos
los que queramos, entonces despachamos la orden con el boton2
la cuestion es que cuando vuelo a agregar articulos,
se tranca el proceso. Justo cuando esta sumando, en esta linea:

Código Delphi [-]
ZQuery1.SQL.Text:=  'Select Sum(Precio) as Suma From Factura';

La primera vez el lo hace bien, todo correcto,
pero la segunda vez ya no pasa de alli.

Hechenle un vistazo al codigo:

Código Delphi [-]
procedure TForm1.Button1Click(Sender: TObject);
begin
  if Edit1.Text<>'' then
    begin
      ZQueryBD.Close;
      ZQueryBD.SQL.Text:= 'Select Codigo From Inventario Where Codigo = '+Edit1.Text;
      ZQueryBD.Open;
      if ZQueryBD.IsEmpty then //Controlar el Codigo del producto
                               //Verifica si es correcto o no entrara a las otras condiciones.
        Begin
          ShowMessage('El Codigo del Producto es Invalido o NO esta Registrado');
        End
      Else
        Begin
          if StrToInt(Edit2.Text)>=1 then
            begin
              DataSourceBD.Enabled:= True;
              ZQueryBD.Close;
              ZQueryBD.SQL.Text:= 'Insert Into Factura (Articulo, Cantidad, Precio) Select Articulo, '+Edit2.Text+', Precio*'+Edit2.Text+' From Inventario Where Codigo = '+Edit1.Text;
              ZQueryBD.ExecSQL;
              ZQueryBD.Close;
              ZQueryBD.SQL.Text:= 'Select * From Factura';
              ZQueryBD.Open;
              ZQuery1.Close;
              ShowMessage('La suma de los precios');
              //Aqui se tranca
              ZQuery1.SQL.Text:=  'Select Sum(Precio) as Suma From Factura';
              ShowMessage('agregado');
              //Justo aqui abajo, no abre el query
              ZQuery1.Open;
              ShowMessage('sumados');
              Edit3.Text:= ZQuery1.FieldByName('Suma').AsString+' BsF';
              Monto:= ZQuery1.FieldByName('Suma').AsString;
            end
          Else
            begin
              ShowMessage('La Cantidad debe ser Mayor o Igual que 1');
            end;
        End;
    end
  Else
    begin
      ShowMessage('Ingrese un Codigo');
    end;
end;


procedure TForm1.Button2Click(Sender: TObject);
Var
  Codigo:Integer;
begin
  DataSourceBD.Enabled:= False;
  ZQueryBD.Close;
  ZQueryBD.SQL.Text:= 'Insert Into RFac (Monto, Fecha, Hora) Values ('+Monto+', Date(), Time())';
  ZQueryBD.ExecSQL;
  ZQuery1.Close;
  ZQuery1.SQL.Text:= 'Select Max(CodigoFactura) as CodigoFactura From RFac';
  ZQuery1.Open;
  Codigo:= ZQuery1.FieldByName('CodigoFactura').AsInteger;
  ZQueryBD.Close;
  ZQueryBD.SQL.Text:= 'Create Table F_'+IntToStr(Codigo)+' (NumArticulo Integer Not Null Primary Key AutoIncrement, Articulo Char(48), Cantidad Integer, Precio Decimal)';
  ZQueryBD.ExecSQL;
  ZQueryBD.Close;
  ZQueryBD.SQL.Text:= 'Insert Into F_'+IntToStr(Codigo)+' (Articulo, Cantidad, Precio) Select Articulo, Cantidad, Precio From Factura';
  ZQueryBD.ExecSQL;
  ZQueryBD.Close;
  ZQueryBD.SQL.Text:= 'Insert Into F_'+IntToStr(Codigo)+' (Precio) Values ('+Monto+')';
  ZQueryBD.ExecSQL;
  ZQueryBD.Close;
  ZQueryBD.SQL.Text:= 'Delete From Factura';
  ZQueryBD.ExecSQL;
  Monto:='';
  Edit3.Text:='0.00 BsF';
  Edit1.Text:='';
end;

Gracias siempre por su tiempo y su apoyo
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible.
Responder Con Cita
  #2  
Antiguo 23-08-2012
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Cuando vuelves a agregar productos, antes o despues de eliminar los datos de la tabla temporal ?.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #3  
Antiguo 23-08-2012
ElMug ElMug is offline
Miembro
NULL
 
Registrado: jul 2012
Posts: 163
Poder: 12
ElMug Va por buen camino
Tal vez tienes que mandar un "commit" despues de cada transaccion, creo que al final de cada ciclo.

Yo no uso Zeos, pero checa a ver si se aplica el concepto de concluir una transaccion antes de empezar otra.
Responder Con Cita
  #4  
Antiguo 23-08-2012
Avatar de martini002
martini002 martini002 is offline
Miembro
 
Registrado: may 2012
Ubicación: Puerto Ordaz - Venezuela
Posts: 175
Poder: 12
martini002 Va por buen camino
Despues de darle click al segundo boton,
luego de agregar los nuevos registros y crear la tabla nueva
con los valores de la nueva factura;
despues de borrar la tabla temporal.

Pienso que podria haber un problema
entre el ZQuery1 del primer boton
y el ZQuery1 del segundo, he intentado con otro ZQuery
pero me da otro error :/
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible.

Última edición por martini002 fecha: 23-08-2012 a las 22:47:33.
Responder Con Cita
  #5  
Antiguo 24-08-2012
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Para mi gusto esta algo desordenado. no entiendo bien el concepto.
Hay variables que son globales, no me parece.
No se que BD usas, eso complica algo mas el asunto.
No entiendo como el articulo y el precio estan en el mismo edit ?
Código Delphi [-]
Select Articulo, '+Edit2.Text+', Precio*'+Edit2.Text+' From Inventario
Bueno, no entiendo como te complicas la vida amigo.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #6  
Antiguo 24-08-2012
Avatar de martini002
martini002 martini002 is offline
Miembro
 
Registrado: may 2012
Ubicación: Puerto Ordaz - Venezuela
Posts: 175
Poder: 12
martini002 Va por buen camino
Bueno estoy usando SQLite,

Esto basicamente, multiplica la Cantidad por el Precio y me da un subtotal
el Edit2 corresponde a la Cantidad, Estoy usando una variable global "Monto"
porque necesito ese dato en el otro Procedimiento.

Código Delphi [-]
Select Articulo, '+Edit2.Text+', Precio*'+Edit2.Text+' From Inventario

Pues sigo estancado aqui, he intentado de todo pero hasta ahora
no he tenido nada de avance :/
si hay un poco de desorden, pero los momentos solo quiero que funcione
ya despues con mas calma cuando este modulo este listo, entonces
comienzo a agregarle los comentarios, y algunas condiciones de control,
detallitos pues
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible.
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
Error en cantidad de columnas. patorecalde Varios 3 12-06-2008 19:11:16
Update un campo sumando existencia (Inventario) enecumene Conexión con bases de datos 29 07-10-2007 22:35:12
Sumando columnas con Qreport ? Coco_jac Varios 5 27-01-2006 14:57:56
error sumando campos weke SQL 2 02-06-2004 14:52:33
Sumando columnas/Filas StartKill Firebird e Interbase 5 27-05-2004 09:42:32


La franja horaria es GMT +2. Ahora son las 08:51:57.


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