Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   Duda en sentencia de firebird (https://www.clubdelphi.com/foros/showthread.php?t=47697)

vivamotos 05-09-2007 08:22:56

Duda en sentencia de firebird
 
Saludos,

Me gustaría saber como puedo hacer que en la clausula SELECT pueda decir hazme la división de la columna 2 entre la 1.
EJEMPLO

SELECT CALIDAD,SUM(TICKETRECORTE.PESO) AS A ,SUM(PRECIOPROV*TICKETRECORTE.PESO) AS B,

y la tercera seria decir columna B dividido por columna A
column 2 / column 1


OTRA DUDILLA

Como puedo hacer en una sentencia select lo siguiente?

SELECT SUM(TICKETRECORTE.PESO)/*3 NO ME DEJA!


Grácias

defcon1_es 05-09-2007 10:07:55

EJEMPLO

Código SQL [-]
SELECT CALIDAD,SUM(TICKETRECORTE.PESO) AS A,
SUM(PRECIOPROV*TICKETRECORTE.PESO) AS B,
SUM(TICKETRECORTE.PESO) / SUM(PRECIOPROV*TICKETRECORTE.PESO) AS C

Cita:

Empezado por vivamotos (Mensaje 228462)
OTRA DUDILLA

Como puedo hacer en una sentencia select lo siguiente?

SELECT SUM(TICKETRECORTE.PESO)/*3 NO ME DEJA!

Esto no lo he entendido,
¿qué es lo que pretendes hacer? ¿dividir por 3 o multiplicar por 3?

defcon1_es 05-09-2007 10:08:48

Ejemplo

Código SQL [-]
select Calidad,sum(ticketrecorte.peso) As A,
Sum(precioprov*ticketrecorte.peso) As B,
sum(ticketrecorte.peso) / Sum(precioprov*ticketrecorte.peso) As C

Pero cuidado con este tipo de sentencias, porque si Sum(precioprov*ticketrecorte.peso)
es CERO o NULL, te saldrá un bonito mensaje de error...

jhonny 05-09-2007 15:18:08

Cita:

Empezado por defcon1_es (Mensaje 228469)
Ejemplo

Código SQL [-]
select Calidad,sum(ticketrecorte.peso) As A,
Sum(precioprov*ticketrecorte.peso) As B,
sum(ticketrecorte.peso) / Sum(precioprov*ticketrecorte.peso) As C

Pero cuidado con este tipo de sentencias, porque si Sum(precioprov*ticketrecorte.peso)
es CERO o NULL, te saldrá un bonito mensaje de error...

De todas formas recuerda que existe la función coalesce en la version 2 de FireBird y en estos casos la he encontrado muy util ;).

RolphyReyes 05-09-2007 15:26:59

Saludos.

Solo para aclararlo COALESCE viene desde FB1.5.

Hasta luego...

vivamotos 10-09-2007 10:48:14

Resuelto pero con otra duda
 
Saludos,

Grácias por las respuestas el problema ha sido resuelto pero ahora tengo otra duda.

La siguiente sentencia me falla

SELECT distinct nombre from tickets,proveedor
where fecha>='01/01/2007 00:00:00' and fecha<='12/31/2007 23:59:59' and salida=1 and tickets.codigo_prov=proveedor.codigo
and nombre NOT IN (select distinct nombre from tickets,proveedor where
fecha>='08/01/2007 00:00:00' and fecha<='08/31/2007 23:59:59' and salida=1 and tickets.codigo_prov=proveedor.codigo)



Cuando pongo el NOT IN patapam, colgado.

Alguna solución o alternativa.

Resumo que hace la sentencia: simplemente quiero que me coja todos los proveedores que han sido introducidos en todo el año y que no esten en la segunda fecha marcada.

basti 10-09-2007 11:17:18

Cuidado con las subconsultas si la tabla es muy grande (y una tabla de tickets suele serlo), porque le puede llevar mucho tiempo realizarla.

Para evitar esto, tienes que tener bien definidos los índices de la tabla. En tu caso, tener un índice por nombre.

De todas maneras esta consulta quedaría más sencilla si utilizas el código del proveedor en vez del nombre, con lo que evitarías relacionar las tablas en la subconsulta, además de que (supongo) tienes índices en la tabla por tickets.codigo_prov y proveedor.codigo. También es posible que te vaya más rápido con un join.

Código SQL [-]
SELECT distinct nombre from tickets left outer join proveedor
on (tickets.codigo_prov = proveedor.codigo)
where fecha>='01/01/2007 00:00:00' and fecha<='12/31/2007 23:59:59' and salida=1 and tickets.codigo_prov NOT IN (select codigo_prov from tickets where
fecha>='08/01/2007 00:00:00' and fecha<='08/31/2007 23:59:59' and salida=1 )


La franja horaria es GMT +2. Ahora son las 20:26:05.

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