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 01-03-2015
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
Campo aggregate dependiente de otro en clientdataset

Hola amigos, estoy haciendo la factura de un Terminal de puesto de venta. Es posible colocar en un clientdataset luego de un campo agreggate otro dependiente? por ejemplo: el total es sum(subtotal)(es la suma de todos los precios por sus respectivas cantidades), entonces pongo total2 que es total menos descuento. total2 depende de total. Otro caso es el vuelto es efectivo menos total2.

Cuando hago esto obtengo: Bit index out of range, es decir si dejo un solo aggregate se soluciona.

¿Que puede ser?
Responder Con Cita
  #2  
Antiguo 01-03-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola giulichajari.

No podes usar el nombre de campo "total" en la expresión del campo total2, creo que la expresión que correspondería es:
Código Delphi [-]
  ClientDataSet1TOTAL2.Expresion:= 'SUM(subtotal) - SUM(descuento)'; // conf. desde el Object Inspector

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #3  
Antiguo 01-03-2015
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
Cita:
Empezado por ecfisa Ver Mensaje
Hola giulichajari.

No podes usar el nombre de campo "total" en la expresión del campo total2, creo que la expresión que correspondería es:
Código Delphi [-]
  ClientDataSet1TOTAL2.Expresion:= 'SUM(subtotal) - SUM(descuento)'; // conf. desde el Object Inspector

Saludos
Entonces vuelto es:
Código Delphi [-]
sum(efectivo) - (sum(subtotal) - sum(descuento))
Responder Con Cita
  #4  
Antiguo 01-03-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola giulichajari.
Cita:
Empezado por giulichajari Ver Mensaje
Entonces vuelto es:
Código Delphi [-]
sum(efectivo) - (sum(subtotal) - sum(descuento))
No conozco el cálculo que deseas realizar, pero si se trata de restarle a "efectivo" la suma de "subtotal" y la suma "descuento", no tendrías el resultado esperado.

Debería ser:
Código:
SUM(efectivo) - (SUM(subtotal) + SUM(descuento))
Por que al suprimir paréntesis precedidos de signo menos, cambian los signos de los términos incluídos en él.

O expresado de forma mas simple:
Código:
SUM(efectivo) - SUM(subtotal) - SUM(descuento)
Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #5  
Antiguo 01-03-2015
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
Cita:
Empezado por ecfisa Ver Mensaje
Hola giulichajari.

No conozco el cálculo que deseas realizar, pero si se trata de restarle a "efectivo" la suma de "subtotal" y la suma "descuento", no tendrías el resultado esperado.

Debería ser:
Código:
SUM(efectivo) - (SUM(subtotal) + SUM(descuento))
Por que al suprimir paréntesis precedidos de signo menos, cambian los signos de los términos incluídos en él.

O expresado de forma mas simple:
Código:
SUM(efectivo) - SUM(subtotal) - SUM(descuento)
Saludos
Me refiero al vuelto para el cliente el total2 es $500 y el cliente entrega $1000
Por lo que dices no puedo colocar total2 en la expresion del campo vuelto entonces debo repetir todo.
Responder Con Cita
  #6  
Antiguo 01-03-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por giulichajari Ver Mensaje
...
Por lo que dices no puedo colocar total2 en la expresion del campo vuelto entonces debo repetir todo.
Si, así es. La expresión "conoce" los nombres de campos de la tabla, pero no el nombre que le diste al campo persistente.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
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
Campo aggregate ClientDataSet en runtime Dclase Conexión con bases de datos 6 14-02-2014 13:17:25
buscar registros de un ClientDataSet a otro clientDataSet novato_erick Conexión con bases de datos 2 02-02-2013 20:48:09
TClientDataSet + Campo Tipo Aggregate mjjj Varios 0 11-08-2012 00:36:07
Asignar el valor de un campo aggregate a un campo de la base TrUnkS Conexión con bases de datos 1 23-02-2010 05:17:42
Copiar Campos de un ClientDataSet a Otro linsua Conexión con bases de datos 4 06-11-2003 21:25:00


La franja horaria es GMT +2. Ahora son las 21:11:44.


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