Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   IIF (tengo problemas) (https://www.clubdelphi.com/foros/showthread.php?t=8738)

Ignacio 31-03-2004 16:57:46

IIF (tengo problemas)
 
En una tabla Paradox almaceno viajes o servicios de transportes en la cual, un campo llamado TipotarifaTRA puede contener un 1 o un 2. Otro campo llamado PrecioTRA que puede contener el precio por tonelada transportada o por todo el viaje. Tambien tiene un campo llamado PesoTRA que contendrá los kilos transportados. Esto es a groso modo, la manera en que están almacenados los importes de cada viaje.

Mi problema comienza cuando por medio del comando SUM deseo obtener el total de dichos importes. Pero como existen dos formas de calcularlo dependiendo del valor de TipotarifaTRA armo lo siguiente:
Select Sum(Iif(TipotarifaTRA=1, PrecioTRA*(PesoTRA/1000), PrecioTRA))

Según lo poco que he leido sobre IIf, la sintaxis es correcta. Esto me hace pensar que el comando IFF no funciona en tablas Paradox o que existe otro problema.

Gracias desde ya.

delphi.com.ar 31-03-2004 17:19:45

Cita:

Empezado por Ignacio
Según lo poco que he leido sobre IIf, la sintaxis es correcta. Esto me hace pensar que el comando IFF no funciona en tablas Paradox o que existe otro problema.

IIF no es una instrucción ANSI SQL, es una extención del ANSI para Access, desconozco si funciona en Paradox, pero lo dudo mucho.

Saludos!

roman 01-04-2004 00:25:51

Como indica delphi.com.ar ésta instrucción no puede usarse con Paradox. Sin embargo podrías intentar algo así:

Código:

select sum(PrecioTRA*(PesoTRA/1000)) as Total
from tarifas
where TipotarifaTRA=1

union

select sum(PesoTRA) as Total
from tarifas
where TipotarifaTRA=2

que te regresará dos registros, uno con la suma de cada caso y ya sólo tendrías que sumar ambos:

Código:

Query.First;
Total := Query.FieldByName('Tota'l).AsFloat;
Query.Next;
Total := Total + Query.FieldByName('Total').AsFloat;

// Saludos

Ignacio 02-04-2004 05:47:34

Muchas gracias, pero el comando "Union" ya lo estoy usando 4 veces en la misma consulta por casos similares al del importe del peso, y agregarle otro para incluir en la misma consulta dicho Importe del flete me potenciaría la cantidad de "Union" haciendo un código de lectura engorrosa. De todas maneras opté por realizar una consultas paralelas que me resuelvan los casos similares y unir sus resultados en un RxMemotyData.

Gracias igualmente y hasta la próxima.

jachguate 02-04-2004 06:59:06

Creo que tratandose de Paradox, te convendria mas (aunque denormalices un poco el modelo) almacenar esta información ya procesada, evitando tener que hacerlo al vuelo.

Otra opción es el uso de campos calculados... y realizar estos (calculos) en el evento OnCalculate del TQuery.

Hasta luego.

;)


La franja horaria es GMT +2. Ahora son las 18:53:37.

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