Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 31-03-2004
Ignacio Ignacio is offline
Miembro
 
Registrado: may 2003
Posts: 77
Poder: 21
Ignacio Va por buen camino
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.
Responder Con Cita
  #2  
Antiguo 31-03-2004
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 26
delphi.com.ar Va por buen camino
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!
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #3  
Antiguo 01-04-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
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
Responder Con Cita
  #4  
Antiguo 02-04-2004
Ignacio Ignacio is offline
Miembro
 
Registrado: may 2003
Posts: 77
Poder: 21
Ignacio Va por buen camino
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.
Responder Con Cita
  #5  
Antiguo 02-04-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
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
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


La franja horaria es GMT +2. Ahora son las 01:56:30.


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