![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
yo lo que haria seria crear un procedimiento que resuelva para un solo ID
Luego llamas a este procedimiento deste Delphi mediante una instruccion SQL, uniendo los diferentes informes asi:
Espero que te guste esta solucion ![]()
__________________
[Crandel] |
|
#2
|
|||
|
|||
|
desde ya gracias a los dos por haber leido y contestado..
bueno estuve averiguando y pareciera que lo de la tabla temporaria es la mejor manera de ir, por lo visto FB no soporta tablas temporarias por lo que tendre que usar la variable CURRENT_TRANSACTION para asegurarme que no haya conflictos en un entorno multiusuario.. lo de los unions esta bueno pero tiene el inconveniente que tenés que modificar dinámicamente el texto de la consulta (si no entendí mal..), si son 3 IDS serían tres UNIONs y así sucesivamente.. mi idea era desacoplar completamente esto de la aplicación.. |
|
#3
|
|||
|
|||
|
lo cual me lleva a la conclusión de que no encontré manera de manejar esto de forma limpia en firebird (lo de limpio es cuestión de gustos obviamente) pero es obvio que esta solución no escala bien.. demasiadas tablas "temporarias" sin sentido (una para cada TIPO_FACTURA, TIPO_CHEQUE, TIPO_CAMBIO, TIPO_MONEDA, etc etc.) creo yo..
|
|
#4
|
||||
|
||||
|
otra idea (no parece muy limpia pero por ahi te gusta), pasale los parametros como registros de una tabla auxiliar de la base de datos.
Luego en un procedimiento vas creando las uniones dinamicamnete de acuerdo a la cantidad de registros de la tabla.
__________________
[Crandel] |
|
#5
|
||||
|
||||
|
se me ocurre una un poco diferente y es algo como lo siguiente:
ya el problema es cuando se manden muchos codigos en la cadena (como tal es algo q se me ocurrio y debe de tener muchos errores pero es solo una idea) Última edición por RONPABLO fecha: 24-11-2006 a las 23:56:26. |
|
#6
|
||||
|
||||
|
lo más fácil desde mi punto de vista es un sql del tipo:
Si te ayudas de un TStringList, puedes usar su propiedad commaText para hacer la tira 3, 4, 5, 6. Yo utilicé un Combobox para que el usuario añada las facturas, así tienes el CommaText a mano y además el usuario tiene comodidades para añadir y eliminar las facturas que quiere ver. Este SQL puedes almacenarlo en un archivo .inc como se hace en la mayoría de paquetes, así puedes modificar el SQL en el ordenador de tu cliente sin tener que recompilar la aplicación. O incluso (y es lo que yo hago), guardas el SQL en una tabla de tu programa, así lo cargas dinámicamente. Hay otros trucos, por ejemplo: Esa constante puedes almacenarla en la BBDD, archivo .inc etc. Inconveniente, no estará compilada nunca en FB. Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
|
#7
|
|||
|
|||
|
hola,
tal vez a alguno le sirva este artículo de la borland developer network al respecto aunque en vez de un SP lo trata con querys.. http://bdn.borland.com/article/32076 saludos! |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| En un stored procedure, ¿Cómo uso un arreglo como param de entrada? | cuxoapat | Firebird e Interbase | 0 | 04-03-2005 18:54:42 |
| como hago este stored procedure | edy_aca | Firebird e Interbase | 2 | 13-01-2005 16:32:26 |
| Ver los Stored Procedure | tgsistemas | SQL | 0 | 06-04-2004 17:18:22 |
| Stored Procedure | tgsistemas | SQL | 1 | 27-02-2004 13:10:33 |
| Pasar Tabla Como Parametro en Stored Procedure | elpinjum | Firebird e Interbase | 3 | 17-10-2003 10:37:41 |
|