Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 05-09-2007
vivamotos vivamotos is offline
Miembro
 
Registrado: ago 2006
Posts: 150
Poder: 18
vivamotos Va por buen camino
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
Responder Con Cita
  #2  
Antiguo 05-09-2007
Avatar de defcon1_es
defcon1_es defcon1_es is offline
Miembro
 
Registrado: mar 2004
Ubicación: Cuenca - España
Posts: 533
Poder: 21
defcon1_es Va por buen camino
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 Ver Mensaje
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?
__________________
Progress Openedge
https://abevoelker.com/progress_open...dered_harmful/


Delphi forever...

Última edición por defcon1_es fecha: 05-09-2007 a las 10:11:16.
Responder Con Cita
  #3  
Antiguo 05-09-2007
Avatar de defcon1_es
defcon1_es defcon1_es is offline
Miembro
 
Registrado: mar 2004
Ubicación: Cuenca - España
Posts: 533
Poder: 21
defcon1_es Va por buen camino
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...
__________________
Progress Openedge
https://abevoelker.com/progress_open...dered_harmful/


Delphi forever...

Última edición por defcon1_es fecha: 05-09-2007 a las 10:13:07.
Responder Con Cita
  #4  
Antiguo 05-09-2007
Avatar de jhonny
jhonny jhonny is offline
Jhonny Suárez
 
Registrado: may 2003
Ubicación: Colombia
Posts: 7.058
Poder: 30
jhonny Va camino a la famajhonny Va camino a la fama
Cita:
Empezado por defcon1_es Ver Mensaje
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 .
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!"

http://www.purodelphi.com/
http://www.nosolodelphi.com/
Responder Con Cita
  #5  
Antiguo 05-09-2007
Avatar de RolphyReyes
RolphyReyes RolphyReyes is offline
Miembro
 
Registrado: ago 2004
Ubicación: Santo Domingo
Posts: 285
Poder: 20
RolphyReyes Va por buen camino
Smile

Saludos.

Solo para aclararlo COALESCE viene desde FB1.5.

Hasta luego...
__________________
Gracias,
Rolphy Reyes
Responder Con Cita
  #6  
Antiguo 10-09-2007
vivamotos vivamotos is offline
Miembro
 
Registrado: ago 2006
Posts: 150
Poder: 18
vivamotos Va por buen camino
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.
Responder Con Cita
  #7  
Antiguo 10-09-2007
[basti] basti is offline
Miembro Premium
 
Registrado: ago 2004
Posts: 388
Poder: 20
basti Va por buen camino
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 )
__________________
Saludos.
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
duda con formato fecha en firebird gmontes Firebird e Interbase 3 12-10-2006 16:11:10
Duda acerca de Firebird joanajj Conexión con bases de datos 2 13-05-2006 05:03:18
duda delphi 8 y Firebird acertij022 Firebird e Interbase 4 27-06-2004 16:06:44
sentencia sql echa abajo firebird CarlosN Firebird e Interbase 4 06-04-2004 00:11:29
Novato en firebird, tengo una duda chakal Firebird e Interbase 2 03-03-2004 13:48:49


La franja horaria es GMT +2. Ahora son las 08:32:38.


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