![]() |
![]() |
| 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
|
||||
|
||||
|
Ok LuNaTk,
El confundido era yo, no leí bien tu descripción e interpreté diferente las cosas... espero esta vez si haberlo entendido como es... Yo probé la siguiente consulta y me funcionó OK en PosgreSQL
Lo que hace recuperar los movimientos mas antiguos que sumen los 250 que buscas o que se aproximen (por debajo a este monto)... entonces teiendo estos datos: Código:
pag_id, pag_monto, pag_status 1;10;"PENDIENTE" 2;8;"PENDIENTE" 3;3;"PENDIENTE" 4;12;"OK" 5;60;"PENDIENTE" 6;20;"PENDIENTE" 7;13;"PENDIENTE" 8;8;"OK" 9;9;"PENDIENTE" 10;15;"PENDIENTE" 11;5;"OK" 12;50;"PENDIENTE" Código:
pag_id, pag_monto, pag_status 1;10;"PENDIENTE" 2;8;"PENDIENTE" 3;3;"PENDIENTE" 5;60;"PENDIENTE" Ahora si quisieras encontrar el número exacto, escogiendo y descartando filas interedias... ahí si te tocaría hacer un procedimiento almacenado o funcion que te ayude.... me refiero a un ejemplo como este: Tengo los siguientes numeros y busco aquellos que me sumen 94... 60 50 20 OK 15 OK 13 OK 12 OK 10 OK 9 8 OK 8 OK 5 OK 3 OK Para llegar a este resultado, tuve que ordenarlos (de menor a mayor o al contrario de igual) y luego aplicar un algoritmo que toma y descarta numeros... bueno eso creo, no se si este equivocado Última edición por gatosoft fecha: 20-05-2012 a las 19:37:22. |
|
#2
|
||||
|
||||
|
asi es gatosoft
ya nos entendimos, pues si, estoy entonces haciendo el stored procedure para realizar esa búsqueda de pagos, si tengo exito compartire el codigo, saludos! tenias razon marcoszorrilla, aprece que es imposible en un query |
|
#3
|
||||
|
||||
|
Creo que, en principio, no se puede hacer.
Debería ser inteligente para descartar una cantidad y sumar otras, y eso actualmente no existe, habría que inventarlo ![]()
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#4
|
||||
|
||||
|
Despues de un buen rato de depuracion, por fin tengo lo que necesito, comparto el código, muy seguramente se puede optimizar, a mi no me gusta usar cursores asi que los implemento en ciclos while.
De manera breve explico lo que hace. Recupero y guardo en memoria los pagos que no se hayan facturado todavia y que el monto sea menor ó igual al importe deseado, guardo en memoria para poder trabajar con esos datos sin tener que acceder a las tablas fisicas debido a que el sistema esta siendo usado y tiene un alto indice de concurrencia. Guardo los valores minimo y maximo de Ids de los pagos para recorrerlos en un ciclo while primario el cual se encargara de recorrer uno a uno los pagos de manera descendente en el monto. Si encuentro un pago igual a el monto que estoy buscando, finalizo el ciclo y muestro los resultados. Si no encuentro un pago igual al monto, entonces tengo uno con un monto menor ya que asi esta establecida la consulta y procedo a realizar una sub-busqueda en la tabla de pagos que cargue en memoria pero iniciando desde los pagos que potencialmente sumados den como resultado la cantidad deseada, es decir no recorro todos los registros, para eso agrego la sentencia where pag_total<=@Total-@pag_total_idx. En el peor de los casos tengo que repetir esta sub-busqueda tantas veces como registros en la sub-busqueda se encuentren, sumando todos los registros encontrados entre si hasta hayar la combinacion correcta. Bueno soy malo para explicar, pero me funciona de maravilla. de una tabla de pagos de el mes de enero 2012, tengo 1766 registros, despues de ejecutar el sp con los parametros 35000,'01/01/2012' obtengo los siguientes resultados Código:
pag_id pag_total 198232 18000.00 198191 2000.00 197846 1956.50 197296 1937.00 196831 1823.50 196806 1812.00 197823 1718.50 198264 1653.50 197260 1557.00 197546 1500.00 198277 1031.00 197692 11.00 Gracias por sus consejos! |
|
#5
|
||||
|
||||
|
Un ultimo ajuste ya que en el caso de que no haya registros que coincidan con la busqueda no se borraba la tabla de resultados, arrojando registros que no cumplian.
Última edición por LuNaTk fecha: 21-05-2012 a las 03:09:19. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Seleccionar un numero determinado de registros de una tabla | NPIdea | Firebird e Interbase | 8 | 26-11-2008 19:50:46 |
| Metodo Ideal para Modificar un valor a todos los Registros mostrados en un DBGrid | Alexis De la Cr | MySQL | 7 | 09-04-2008 14:00:00 |
| Duda registros valor 0 sql | drykea | SQL | 6 | 13-03-2008 17:43:52 |
| Eliminar de un Select registros con valor de un campo igual | danilo_candales | SQL | 3 | 15-01-2008 15:32:55 |
| Registros de un campo blob que contienen un string determinado | juanpe | Firebird e Interbase | 2 | 07-03-2007 18:44:26 |
|