FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
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. |
#2
|
||||
|
||||
Cita:
Saludos!
__________________
delphi.com.ar Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla. |
#3
|
||||
|
||||
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 Código:
Query.First; Total := Query.FieldByName('Tota'l).AsFloat; Query.Next; Total := Total + Query.FieldByName('Total').AsFloat; |
#4
|
|||
|
|||
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. |
#5
|
||||
|
||||
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.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
|
|
|