Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 08-04-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
sentencia sql firebird

Hola amigos,
No sabia como titular el post para que sea claro, pero necesitaba saber si esta sentencia es valida o tiene alguna fisura.

Código SQL [-]
select sum(a.cantidad*a.preciocoste) as total, sum(a.cantidad*a.PRECIOCOSTE*(b.iva/100)) as totaliva
from COMPRASDETALLE a, productos b
where a.ID_COMPRA=22 and a.ID_PRODUCTO=b.ID_PRODUCTO

la idea es, en un entorno donde voy metiendo los productos en una factura de compra en la que la estructura es:

cantidad, nombreproducto, preciocoste, preciototal(sin iva)

esos datos estarian en la tabla de comprasdetalle, y en la tabla de productos el iva.

Metiendo cada vez un producto, me actualizaria el total sin iva y el iva.

No se si esa sentencia sql se debe hacer asi o hay alguna otra forma usando un inner join.
Mas que nada por hacer las cosas correctamente aunque funcionen.

gracias

Última edición por ecfisa fecha: 08-04-2016 a las 04:53:49. Razón: ajustar el código para visualización completa
Responder Con Cita
  #2  
Antiguo 08-04-2016
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 15
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
No es mas facil probarla?

Yo hice un simple SELECT * FROM A, B y ni se quejo

Hay varios tipos de joins en Firebird, en el sitio de IBExpert hay buena documentacion. De hecho, por lo menos en la busqueda apurada que hice, es el unico que menciona la sintaxis como la que pusiste vos: omitiendo el tipo de join

Algunos ejemplos validos

Código SQL [-]
  SELECT * FROM A, B
 
  SELECT * FROM A JOIN B

  SELECT * FROM A INNER JOIN B ON (A.Id = B.Id)
Responder Con Cita
  #3  
Antiguo 08-04-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
gracias por contestar
Si, probarla si la he probado, de hecho uso flamerobin y funciona bien.
La pregunta era simplemente si asi estaba bien la sentencia sql o hay alguna otra forma mas optimizada o mas rapida para hacer eso mismo.

gracias
Responder Con Cita
  #4  
Antiguo 08-04-2016
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 15
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
Revisa estos articulos:

Entendiendo a los Join
Join Implicito y Join Explicito
Inner Join y Outer Join
Natural Join y Cross Join
Responder Con Cita
  #5  
Antiguo 08-04-2016
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.038
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por anubis Ver Mensaje
No se si esa sentencia sql se debe hacer asi o hay alguna otra forma usando un inner join.
Es lo mismo, internamente la sentencia que has escrito, la traduce el compilador con inner join. Por lo que el resultado es el mismo.
Al menos eso es lo que me explicaron hace muuuuuuchos años, no sé si seguirá igual.
Responder Con Cita
  #6  
Antiguo 08-04-2016
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
dos cositas (tonterías):
- Supongo estarás en dialecto 3, porque dependiendo de los tipos de cada campo, esa división por 100, no retornaría el valor correcto en dialecto 1. Entiendo que usas el 3 y no tienes problemas con BBDD antiguas.

- Los alias usados en ese SQL puede ser un infierno cuando tengas más tablas. Yo por ejemplo uso la primera letra de cada palabra: COMPRADETALLES CD, PRODUTOS P. Usa dos letras o como te sea fácil, lo agradecerás al leer el select: sum(cd.cantidad*cd.PRECIOCOSTE*(p.iva/100))

En cuanto a tu pregunta original, entiendo que usas claves primarias y ajenas (foráneas), así que está optimizada. Siempre que puedas, usa índices simples en Firebird. Me refiero a que no crees un índice en la tabla formado por dos o más campos , Firebird solo los usa en casos muy concretos.

Saludos.
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #7  
Antiguo 09-04-2016
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
Gracias por la, información, me queda claro q mientras, funcione no hay problema.
Solo q en la, página firebird21 habla de optimizar filtros y consultas para filtrar datos

Enviado desde mi Moto G 2014 mediante Tapatalk
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
No Autoincrementa firebird en sentencia Insert Into MartinS SQL 4 16-03-2012 11:28:30
Campo Calculado con la Sentencia if en FireBird DasGrun Firebird e Interbase 3 29-08-2011 23:31:56
Error en concatenacion de Sentencia SQL, Firebird 2.5 Adrian Murua SQL 15 02-04-2011 00:08:00
Duda en sentencia de firebird vivamotos Firebird e Interbase 6 10-09-2007 11:17:18
sentencia sql echa abajo firebird CarlosN Firebird e Interbase 4 06-04-2004 00:11:29


La franja horaria es GMT +2. Ahora son las 00:53:26.


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