Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Coloboración Paypal con ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 22-08-2011
Avatar de fjcg02
[fjcg02] fjcg02 is offline
Miembro Premium
 
Registrado: dic 2003
Ubicación: Zamudio
Posts: 1.418
Poder: 24
fjcg02 Va camino a la fama
Prueba a ver qué tal te va esta sentencia...


Código SQL [-]
select  C.nfactura, C.fechapago, V.tipoCobro,  current_date - C.fechapago as DIAS,
case when V.tipoCobro = 'SEMANAL' and (current_date - C.fechapago > 14)
   then 'ATRASADO'
else
  case when V.tipocobro = 'QUINCENAL' and (current_date - C.fechapago > 30)
    then 'ATRASADO'
  else
    case when current_date - C.fechapago > 60
      then 'ATRASADO'  /* 'MENSUAL' */
     end
  end
end  AS ESTADO

from cobros C
inner join ventas V on (C.nfactura=V.nfactura)
where C.valor is null

y nos cuentas.

Qué hace:
- une la tabla ventas y cobros...
- filtra los cobros con valor = nulo ( supongo que son los que no están cobrados)
- dependiendo del tipo de cobro (semanal, quincenal, mensual ) calcula si ha pasado el tiempo suficiente para considerarlo pendiente.

Para comprobar, quita el filtro de pago nulo, y comprobarías si calcula bien para todo tipo de pago....

Añadir la tabla de clientes te lo dejo a ti si el resultado es el bueno.

Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino -
Responder Con Cita
  #2  
Antiguo 22-08-2011
Avatar de ingabraham
ingabraham ingabraham is offline
Miembro
 
Registrado: ago 2007
Posts: 614
Poder: 19
ingabraham Va por buen camino
Lightbulb

Ok excelente bueno el codigo
1. Si no esta atrasado el cobro de una factura que valor
Toma el estado

2. Una factura puede tener varios cobros asi.
Tabla cobro



001
01/08/11
2000

001
15/08/11
3000

... Asi

Osea hay k buscar la ultima fecha de cobro
__________________
Enseñar es la virtud de un sabio.
Responder Con Cita
  #3  
Antiguo 22-08-2011
Avatar de fjcg02
[fjcg02] fjcg02 is offline
Miembro Premium
 
Registrado: dic 2003
Ubicación: Zamudio
Posts: 1.418
Poder: 24
fjcg02 Va camino a la fama
Ok excelente bueno el codigo
Gracias.

1. Si no esta atrasado el cobro de una factura que valor Toma el estado
Ninguno, en tu exposición buscas cobros retrasados. Faltaría añadir la condición de retraso en el where para que solo salgan los atrasados.

2. Una factura puede tener varios cobros asi. Osea hay k buscar la ultima fecha de cobro.
discrepo, un cobro está atrasado o no. Si tengo una factura con 35 cobros, puedo tener desde 0 a 35 cobros atrasados. En otro caso, no es eso lo que buscas, es decir, la premisa de los resultados sería distinta.

Espero haberte puesto sobre la pista...

Saludos
Nota: el case que he escrito se puede simplificar mucho si se restringe sólo a cobros atrasados, pero he puesto la estructura completa para que con un poco de ganas y paciencia se puedan contemplar todos los casos, es decir, los cobros atrasados y no atrasados. Si tienes problemas, nos comentas para echarte una mano.
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino -
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


La franja horaria es GMT +2. Ahora son las 19:57:16.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi