Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #21  
Antiguo 08-09-2008
ninguno ninguno is offline
Miembro
 
Registrado: sep 2008
Posts: 45
Poder: 0
ninguno Va por buen camino
Hola

Cita:
Empezado por egostar Ver Mensaje
Acaso hemos dicho lo contrario ????
Sí, fíjate mi cita de Caral

Cita:
Empezado por egostar Ver Mensaje
, Pues por desgracia hemos estado suponiendo todo este tiempo muchas cosas, el problema es que no se nos pone la información necesaria para llegar a una solución.......
Como he dicho, si en un mes puede haber más de 1 tipo de condición y no todos los registros están informados, será difícil, por no decir imposible, hacer esa suma dado que NO podrás saber a qué condición agregarle esos registros sin condición.
Responder Con Cita
  #22  
Antiguo 08-09-2008
lledesma lledesma is offline
Miembro
 
Registrado: abr 2004
Posts: 43
Poder: 0
lledesma Va por buen camino
Perdon si generé lios, no era mi intencion. Igual gracias por los aportes. Y me corrijo, El resto de informacion que falta en los datos no tiene relevancia, por cuanto no sirve a los propositos que busco, el ejemplo que pongo a consideración es tal cual se utiliza en el procedimiento. De nuevo, gracias
__________________
Atentamente
Luis
Responder Con Cita
  #23  
Antiguo 08-09-2008
Avatar de gmontes
gmontes gmontes is offline
Miembro
 
Registrado: jul 2004
Ubicación: Culiacán, Sinaloa, México
Posts: 668
Poder: 20
gmontes Va por buen camino
Cita:
Empezado por lledesma Ver Mensaje
Hola comunidad:

Recurro a uds por que puedo dar con la solucion:
tengo p.e. 3 registros
idcliente - mes - condicion importe
1 1 N 100
1 1 null -50
1 1 null -20


y tengo que obtener

1 1 N 30
Utilizo firebird 2.0 y es en un procedimiento almacenado

Actualmente uso:
Código SQL [-] select idcliente,mes,condicion,sum(importe) from cuentas group by idcliente,mes,condicion


obtengo
1 1 N 100
1 1 null -70

Muchas gracias

si la condicion no importa, solo quitala del select y del group
__________________
Todos llevamos nuestros demonios a cuestas..
Responder Con Cita
  #24  
Antiguo 08-09-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Cita:
Empezado por gmontes Ver Mensaje
si la condicion no importa, solo quitala del select y del group
Ahí esta el problema la condición si importa, como he dicho al principio, con esta consulta.

Código SQL [-]
select idcliente, mes, sum(importe) from cuentas group by idcliente,mes

ya obtenemos lo que el amigo quiere

Código:
5  1  M  50
5  2  B  40
5  3  C  35
pero no sabemos a que condición pertenece cada uno de esos registros, ahora si aumentamos en el group by la condición, obtrendremos este resultado ya que nos va a agrupar por ese campo mas.

Código:
5  1  null  -50
5  1  M     100
5  2  null  -30
5  2  B      70
5  3  null   -5
5  3  C      35
y es lo que no se quiere, entonces la pregunta sería como añadir mas campos en una consulta con group by pero sin colocarlo en el group by para que no afecte en la agrupación. De hecho si utilizamos group by y queremos mostrar un campo en el select tenemos que añadirlo en el group by.

La verdad yo también quisiera saber como hacer eso.

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #25  
Antiguo 08-09-2008
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
A mi no me hagáis caso, de estas cosas no se, solo opino.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #26  
Antiguo 08-09-2008
Avatar de gmontes
gmontes gmontes is offline
Miembro
 
Registrado: jul 2004
Ubicación: Culiacán, Sinaloa, México
Posts: 668
Poder: 20
gmontes Va por buen camino
el problema es que

tiene lo siguiente:

1 1 N 100
1 1 null -50
1 1 null -20

y quiere obtener 1 1 N 30

select idcliente,mes,condicion,sum(importe) from cuentas group by idcliente,mes,condicion

obtiene
1 1 N 100
1 1 null -70

lo cual es valido porque agrupa por por condicion

o sea que si la condicion fuera por B

1 1 B 200
1 1 N 100
1 1 null -50
1 1 null -20

el quisiera obtener
1 1 B 130

es decir, que las condiciones Null se sumen a cualquier condicion que se seleccione.

pues que en el procedure tenga dos select

select idcliente,mes,condicion,sum(importe) from cuentas where condicion = "N" group by idcliente,mes,condicion



y la segunda

select idcliente,mes,condicion,sum(importe) from cuentas where condicion is NULL group by idcliente,mes,condicion

y que los campos de salida del importe sea la suma de ambas condiciones
__________________
Todos llevamos nuestros demonios a cuestas..
Responder Con Cita
  #27  
Antiguo 08-09-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Te endiendo amiguito GMontes, pero si nos fijamos en los datos que nos puso si sabemos a donde pertenecen los null, los registros en rojo le pertenecen al mes 1, los verdes al mes 2 y el azul al mes 3, por eso decía que con la agrupación de solo cliente y condición ya obtenemos lo que queremos.

Cita:
Empezado por lledesma Ver Mensaje
idcliente -------mes------------ condicion-----------importe
5---------------1-----------------M----------------- 100
5---------------1-----------------null--------------- -30
5---------------1-----------------null--------------- -20
5---------------2-----------------B----------------- 70
5---------------2-----------------null--------------- -20
5---------------2-----------------null--------------- -10
5---------------3-----------------C---------------- 40
5---------------3-----------------null-------------- -5
Acabo de hacer una prueba de esta consulta y si funciona, se obtiene lo que quiere el amigo, por lo menos a mi me funciona, pero nose que tan bien pueda estar. Lo he probado en Firebird por si acaso.

Código SQL [-]
select c1.idcliente, c1.mes, c1.condicion, 
        (select sum(importe) 
         from clientes where idcliente=c1.idcliente and mes=c1.mes group by id_cliente, mes)
from clientes c1
where condicion  is not Null

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.

Última edición por Caro fecha: 08-09-2008 a las 17:17:32.
Responder Con Cita
  #28  
Antiguo 08-09-2008
[egostar] egostar is offline
Registrado
 
Registrado: feb 2006
Posts: 6.557
Poder: 25
egostar Va camino a la fama
Hola amiguita [Caro]

Y que pasaría si en un mismo mes tiene las opciones N,M,B,C,X,Y,Z y tiene el mismo cliente varias veces.

Ahi es donde yo tengo la duda de que se pueda hacer así como lo plantea lledesma

Yo creo que hace falta mas información para poder "adivinar" este asunto.

Salud OS
__________________
"La forma de empezar es dejar de hablar y empezar a hacerlo." - Walt Disney
Responder Con Cita
  #29  
Antiguo 08-09-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Cita:
Empezado por egostar Ver Mensaje
Y que pasaría si en un mismo mes tiene las opciones N,M,B,C,X,Y,Z y tiene el mismo cliente varias veces.
Ahi es donde yo tengo la duda de que se pueda hacer así como lo plantea lledesma
Yo creo que hace falta mas información para poder "adivinar" este asunto.
En ese caso egopolice , ya no funciona lo ultimo que puse, yo me he basado en el ultimo ejemplo y explicación que puso Iledesma.

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #30  
Antiguo 08-09-2008
[egostar] egostar is offline
Registrado
 
Registrado: feb 2006
Posts: 6.557
Poder: 25
egostar Va camino a la fama
Cita:
Empezado por Caro Ver Mensaje
En ese caso egopolice , ya no funciona lo ultimo que puse, yo me he basado en el ultimo ejemplo y explicación que puso Iledesma.

Saluditos
Pues si, me parece que el buen amigo lledesma nos está dando las cosas a cuenta gotas

Salud ITOS

PD, Apurale que ya veo que varios tienen ganas de festejar a un nuevo milenario
__________________
"La forma de empezar es dejar de hablar y empezar a hacerlo." - Walt Disney
Responder Con Cita
  #31  
Antiguo 08-09-2008
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 24
maeyanes Va por buen camino
Hola...

Cita:
Empezado por egostar Ver Mensaje
Hola amiguita [Caro]

Y que pasaría si en un mismo mes tiene las opciones N,M,B,C,X,Y,Z y tiene el mismo cliente varias veces.

Ahi es donde yo tengo la duda de que se pueda hacer así como lo plantea lledesma

Yo creo que hace falta mas información para poder "adivinar" este asunto.

Salud OS
Pues según entiendo (y a lo mejor entiendo mal ), para cada mes solo puede existir una condición con valor (importes positivos) y varias nulas (importes negativos), de tal forma que, si entendí bien, la consulta de Caro debería servir bien...


Saludos...
Responder Con Cita
  #32  
Antiguo 08-09-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Cita:
Empezado por egostar Ver Mensaje
PD, Apurale que ya veo que varios tienen ganas de festejar a un nuevo milenario
Espero llegar mañana amiguito , muchas gracias por fijarte .

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #33  
Antiguo 08-09-2008
hach hach is offline
Miembro
 
Registrado: mar 2007
Ubicación: Bariloche, Argentina
Posts: 44
Poder: 0
hach Va por buen camino
A ver si entendi...

Hola otra vez!!!
A ver si entendi:
1) la factura tiene una condicion y un importe
2) los pagos tienen importes pero no condicion

es asi?

La unica forma de hacer lo que querés es saber la condicion de los pagos, y como no la tienes, la unica forma sería si podés vincular un pago a una determinada factura
Es eso posible? Un pago corresponde a una factura determinada? Tenés forma de vincularlos mediante los datos que tenés?
Si es así, es sencillo, basta con traer la condicion de la factura a la cual pertenece el pago en el select
Si no es asi, no le des mas vueltas...

en algun lado dices:

Cita:
necesito saber por cada mes el saldo y la condicion que tenia el cliente en ese mes asumiento que los nullos tienen que tener el valor de la condicion correspondiente a la factura
La condicion es propia del cliente?
Podrias vincular el cliente con el pago, y obtener la condicion
pero si cambia de mes a mes, solo obtendrias la ultima condicion, salvo que lleves un historico de condiciones...



Saludos

Pablo
Responder Con Cita
  #34  
Antiguo 08-09-2008
Avatar de Delphius
[Delphius] Delphius is offline
Miembro Premium
 
Registrado: jul 2004
Ubicación: Salta, Argentina
Posts: 5.582
Poder: 25
Delphius Va camino a la fama
Yo todavía no comprendo bien lo que busca (por empezar que no me queda totalmente claro como está estructurada la tabla) y esquivé al hilo lo más que pude.
Me acerco ahora a preguntarle, o aconsejarle (no me decido si es una duda o o un consejo) ¿Consideraste estructurar la tabla y/o la información de otra manera? ¿Podríamos conocer mejor la estructura de tus tablas?

Saludos,
__________________
Delphius
[Guia de estilo][Buscar]
Responder Con Cita
  #35  
Antiguo 08-09-2008
lledesma lledesma is offline
Miembro
 
Registrado: abr 2004
Posts: 43
Poder: 0
lledesma Va por buen camino
Hola a todos

Creo que Caro es la que resumio un poco lo que no supe explicar

cita:
Cita:
...y es lo que no se quiere, entonces la pregunta sería como añadir mas campos en una consulta con group by pero sin colocarlo en el group by para que no afecte en la agrupación. De hecho si utilizamos group by y queremos mostrar un campo en el select tenemos que añadirlo en el group by...


La estructura esta armada de ese modo y no puede modificarla.
Cada cliente puede tener solo una factura por mes con cualquier tipo de condicion y sus respectivos pagos, valores negativos, estan asociados a la factura por idcliente,ano,mes.

La informacion no se va dando a cuenta gotas, se hace conforme a la discusion de este foro.
__________________
Atentamente
Luis
Responder Con Cita
  #36  
Antiguo 09-09-2008
[egostar] egostar is offline
Registrado
 
Registrado: feb 2006
Posts: 6.557
Poder: 25
egostar Va camino a la fama
Cita:
Empezado por lledesma Ver Mensaje
Creo que Caro es la que resumio un poco lo que no supe explicar
Pues nuestra amiguita [Caro] te lo dijo desde el post # 3 de este hilo.

Cita:
Empezado por lledesma Ver Mensaje
La informacion no se va dando a cuenta gotas, se hace conforme a la discusion de este foro.


Salud OS
__________________
"La forma de empezar es dejar de hablar y empezar a hacerlo." - Walt Disney
Responder Con Cita
  #37  
Antiguo 09-09-2008
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Me canso y no me dais la solución, a ver si os apuráis.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #38  
Antiguo 09-09-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Cita:
Empezado por lledesma Ver Mensaje
Cada cliente puede tener solo una factura por mes con cualquier tipo de condicion y sus respectivos pagos, valores negativos, estan asociados a la factura por idcliente,ano,mes.
Con cualquier tipo de condición pero no con dos o mas condiciones para el mismo mes, si he entendido bien, entoces Iledesma la ultima consulta que te puse debería funcionarte, pruebala, es esta.

Código SQL [-]
select c1.idcliente, c1.mes, c1.condicion, 
        (select sum(importe) 
         from clientes where idcliente=c1.idcliente and mes=c1.mes group by id_cliente, mes)
from clientes c1
where condicion  is not Null

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #39  
Antiguo 09-09-2008
hach hach is offline
Miembro
 
Registrado: mar 2007
Ubicación: Bariloche, Argentina
Posts: 44
Poder: 0
hach Va por buen camino
Ya va, ya va Caral

Cita:
Me canso y no me dais la solución, a ver si os apuráis.
Saludos
A pedido de Caral, aca va un aporte

Se me ocurre crear un view

Código SQL [-]
CREATE VIEW CLIENTES_VIEW(
    IDCLIENTE,
    MES,
    CONDICION,
    IMPORTE)
AS
select c.idcliente, c.mes, c.condicion, c.importe
from clientes c
where c.condicion is not null
union
select c.idcliente, c.mes
, (select c2.condicion from clientes c2 where c2.condicion is not null and c2.idcliente=c.idcliente and c2.mes=c.mes)
, c.importe
from clientes c
where  c.condicion is null
;

y despues hacer el select sobre el view


Código SQL [-]
select idcliente, mes, condicion, sum(importe)
from clientes_view
group by idcliente, mes, condicion
order by idcliente, mes


Saludos
Responder Con Cita
  #40  
Antiguo 10-09-2008
lledesma lledesma is offline
Miembro
 
Registrado: abr 2004
Posts: 43
Poder: 0
lledesma Va por buen camino
Muchas gracias por los aporte.

Tengo un problema con mi firebird, pero pruebo y les comento.
Gracias
__________________
Atentamente
Luis
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
como sumar una fecha esimon OOP 16 06-09-2007 19:19:07
Como Ingresar Valores En Blanco O Nulos En Access JanoRod Conexión con bases de datos 1 16-11-2005 15:40:48
Como Sumar en Rave Wascar Impresión 1 21-04-2005 18:45:12
S.O.S como selecciono campo nulos Ryu SQL 3 11-04-2005 16:40:50
cómo sumar mariajoiz SQL 3 27-06-2003 14:00:39


La franja horaria es GMT +2. Ahora son las 18:10:12.


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