![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
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:
La primera vez el lo hace bien, todo correcto, pero la segunda vez ya no pasa de alli. Hechenle un vistazo al codigo:
Gracias siempre por su tiempo y su apoyo ![]()
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. |
#2
|
||||
|
||||
Hola
Cuando vuelves a agregar productos, antes o despues de eliminar los datos de la tabla temporal ?. Saludos
__________________
Siempre Novato |
#3
|
|||
|
|||
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. |
#4
|
||||
|
||||
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. |
#5
|
||||
|
||||
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 ? Bueno, no entiendo como te complicas la vida amigo. ![]() ![]() Saludos
__________________
Siempre Novato |
#6
|
||||
|
||||
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.
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. |
#7
|
||||
|
||||
Hola
Sigo sin entender. Cuando se hace una factura esta tiene un numero UNICO. Se hace sobre la tabla directa y si se requiere eliminar un item se elimina sin problemas. Cuando usas una tabla temporal no necesitas eliminar los datos ya que te podrian servir de algo, pero lo veo innecesario. Lo que no veo es ningun numero que identifique la factura. No vi el signo de multiplicar, por eso me parecio raro, aun asi creo que estas complicandote la vida sin necesidad. Saludos
__________________
Siempre Novato |
#8
|
||||
|
||||
Cita:
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#9
|
||||
|
||||
Cita:
pero no puedo leerme todo ese libro para poder resolver este problemita, te agradeceria aun mas, si me dijeras mas o menos que partes me recomiendas, a mi me gusta ir aprendiendo de acuerdo a las necesidades, yo tengo la Cara Oculta de Delphi 6, no se si tambien sea conveniente, ademas tengo a mano el manual de SQL que lo he venido leyendo a medida que estoy manejando estas BD, pues soy nuevo con esto. Edito, No habia leido tu comentario Caral. Mira, el codigo de la factura se guarda, uso una tabla para almacenar los registros de: NumeroFactura y MontoFactura para que se haga mas facil para mi la lectura de este. uso la tabla temporal porque necesito mostrarla en un DBGRid, y alli se editara que es lo que queremos agregar y eliminar o modificar, una vez tengamos eso listo, entonces procedemos a guardar y registrar todo Gracias Saludos
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. Última edición por martini002 fecha: 24-08-2012 a las 02:00:56. |
#10
|
||||
|
||||
Hola
Busca un commit. ZQueryBD.commit. Me avisas si esta. saludos
__________________
Siempre Novato |
#11
|
||||
|
||||
No creo que hay ZQueryBD.commit;
pero si logre encontrar un ZQueryBD.CommitUpdates; :/
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. |
#13
|
||||
|
||||
Bueno,
probe esto que me dices, pero me da un error, dice que no puede ejecutar esto: "ZQueryBD.CommitUpdates;" si esta cerrado, entonces lo coloque asi:
Y continua pues, pero me sigue dando el error incial, no puedo agregar otra factura.
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. |
#14
|
||||
|
||||
Hola
Pensando............ Saludos PD: No te desesperes, estamos en esto.
__________________
Siempre Novato |
#15
|
||||
|
||||
Te lo agradezco, yo he estado
pensando en esto mucho mucho, inclusive, en cambiar la logica y crearlo de otra forma mas eficiente.
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. |
#16
|
||||
|
||||
Hola
A ver por partes que hacemos. Yo diria que no necesitas dos consultas para la suma, cambiaria por esto: Empecemos por aqui, me dices si te sirve o si te gusta. ![]() Saludos
__________________
Siempre Novato |
#17
|
||||
|
||||
Me gusto mucho esa solucion,
porque acortas bastante el codigo, ya no presenta el error cuando agregaba otro producto, pero ahora me presenta un error en el segundo boton, se tranca en la linea que esta descrita abajo, y entonces no crea las tablas ni borra la temporal tampoco. creo que podemos aplicar la misma tecnica que arriba, intentare a ver como me va ![]() mira aqui:
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. |
#18
|
||||
|
||||
Hola
La verdad estoy algo perdido. Me gustaria saber: 1- que campos tiene la tabla factura. 2- que campos tiene la tabla RFac 3- estas creando una tabla por cada numero de factura ???? Saludos
__________________
Siempre Novato |
#19
|
||||
|
||||
Cita:
pero hasta ahorita no he logrado dar con un formato "amigable" para lograr almacenar todos los detalles de cada factura en una sola tabla, Vamos con los campos: Estos son los DDL que me da el SQLite Personal Expert Para Tabla Factura Código:
CREATE TABLE [Factura] ( [Articulo] CHAR(48), [Cantidad] INT, [Precio] DECIMAL); Código:
CREATE TABLE [RFac] ( [CodigoFactura] INTEGER NOT NULL PRIMARY KEY, [Monto] DECIMAL, [Fecha] DATE, [Hora] TIME);
__________________
El Conocimiento se puede compartir, pero la Experiencia es totalmente Intransferible. |
#20
|
||||
|
||||
Hola
Lo modificamos del todo ? Saludos
__________________
Siempre Novato |
![]() |
|
|
![]() |
||||
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 |
![]() |
|