FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
Registros que suman un valor determinado
Hola estoy tratando de realizar un query que me devuelva los registros que suman en uno de sus campos una cantidad determinada.
Tengo una bd que almacena pagos, estos pagos tienen un id, fecha, no. de cuenta, tipo de pago, y el monto del pago, requiero obtener los registros que sumen una cantidad determinada, por ejemplo obtener los registros que sumados por el monto del pago sumen 200, 300 . . . o cualquier valor. He intentado hacer algo asi ...
pero obviamente me manda un error diciendo que la columna pago no se puede seleccionar porque no esta bajo una clausula group by ... pero si la agrupo por el pag_id que viene siendo la llave de la tabla, entonces me va a devolver solo los registros que sean igual a 250. pero el detalle esta en que no se trata de buscar un registro identico porque muchas veces no lo hay, entonces tengo que recuperar uno de 100, otro de 100 y uno de 50 (por dar un ejemplo), para que me sume la cantidad que busco entonces espero recuperar esas 3 claves primarias ó tantas claves como pagos se sumen para obtener la cantidad deseada... me pueen echar una mano? |
#2
|
||||
|
||||
O te estás explicando mal, o lo que quieres es imposible, si sumas los elementos de una tabla sin ninguna condición, (Where), siempre te va a sumar todos los elementos y te arrojará el mismo resultado, a no ser que entre una suma y otra haya habido cambios en la tabla.
Y si utilizas group by que sospecho que va por ahí la solución, nunca podrás obtener los Id, como mucho podrás obtener el mayor, menor, la media, etc. Así que creo que toca explayarse más ampliamente sobre el tema. Un Saludo.
__________________
Guía de Estilo de los Foros Cita:
|
#3
|
||||
|
||||
quise negarme a creer que es imposible...
muy bien voy a intentar explicarlo mejor, la tabla pago contiene el registro de todos los pagos realizados, estoy hablando de un sistema de cobro de agua. Listare algunas de las columnas principales pag_id, pag_fecha, pag_monto, pag_status el interes de este query es, ya que no todos los pagos son facturados en el mes que le corresponde, algunos usuarios piden factura en el siguiente mes, entonces tengo la necesidad de generar esa factura con varios pagos hechos en el mes actual, entonces necesito que la consulta me devuelva los pagos en donde la suma por el campo pag_monto sea igual a una determinada cantidad. P.Ej. el mes anterior un usuario (por x ó y) olvido facturar un pago de 1000 pesos, para ese mes anterior yo genere una factura global de venta al publico en general con lo que cerre mi periodo, entonces el usuario al siguiente mes me la solicita, yo entro en discusion con el diciendole que ya no se puede generar por x razones fiscales etc. Pero el round lo gana el cliente y me veo obligado a generar en este mes una factura por esos 1000 pesos. En primer lugar no puedo usar el registro de pago original porque ya fue tomado para generar la factura global, entonces tengo que buscar dentro de los pagos del mes actual y dentro de los pagos que no facturan individualmente, los registros que sumados me den 1000 pesos sin importar si va a encontrar 1, 2, 3 o n registros, lo ideal es que encontrara otro registro de 1000 pesos y listo pero muchas veces hacen pagos donde forzosamente tengo que agrupar ó sumar mas de un pago para obtener la cantidad que busco. La unica condicion que puedo agregar a la clausula where es la fecha, que sean pagos del mes actual, pero aun asi no se como obtener los Id de los registros De pronto he pensado que por medio de una simple consulta no es posoble, y quiza tenga que hacerlo con cursores para ir probando con todas las combinaciones posibles ... |
#4
|
||||
|
||||
Hola LuNaTk,
En primer lugar, el motor de base de datos te esta exigiendo que utilices la clausula Group By... es obligatoria siempre que estes trabajando con Sum, count, avg, etc... Esto aplica para todos los motroes de base de datos, pues es parte del estandar SQL-92. (aunque parezca redundante es necesario) Por otro lado, veo que estamos un poco confundidos, pues la clausula Having es un where a nivel de agrupación, asi que no hay problema ... ¿ya intentaste con la siguiente sentencia?
debe darte el resultado que esperas... La siguiente sentencia (Dependiedo de si el motor que usas soporta subquerys) deberia darte el mismo resultado...
un saludo, |
#5
|
||||
|
||||
Hola [gatosoft]
Asi es el having hace el where para el operador Sum. El query que me sugieres es valido, pero, como el pag_id es la llave primaria y es identity, entonces es lo mismo que poner
Porque al agruparlo por la clave primaria, no sumas mas que el total de ese mismo registro. Con ese query estoy buscando los pagos con el total igual a 250 y como primer opcion es aceptable, es decir encontrar un pago con el monto igual al deseado. Pero suponiendo que no tengo ningun otro pago por 250, pero si tengo muchos de 100 y muchos de 50, el query tendria que devolverme ya sea dos de 100 y uno de 50, ó bien 1 de a 100 y 3 de 50, ó bien 5 de a 50... Existe forma de lograr esto con un query? |
#6
|
||||
|
||||
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. |
|
|
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 |
|