PDA

Ver la Versión Completa : Duda en sentencia de firebird


vivamotos
05-09-2007, 08:22:56
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

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


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

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
Ejemplo

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
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.


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 )