Código de MySQL - Obtener los meses no pagados de un cliente

<<>>
Imágen de perfil

Obtener los meses no pagados de un clientegráfica de visualizaciones


MySQL

estrellaestrellaestrellaestrellaestrella(1)
Publicado el 06 de Febrero del 2017 por xve
1.407 visualizaciones desde el 06 de Febrero del 2017. Una media de 49 por semana
Esta consulta, soluciona el problema de saber que meses no ha pagado un cliente su cuota durante un año dado.

Imaginamos que un cliente ha pagado cinco meses el recibo durante un año... como sabemos que meses no ha pagado?

Versión 1.0
estrellaestrellaestrellaestrellaestrella(1)

Actualizado el 02 de Mayo del 2017 (Publicado el 06 de Febrero del 2017)gráfica de visualizaciones de la versión: Versión 1.0
1.408 visualizaciones desde el 06 de Febrero del 2017. Una media de 49 por semana
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

Para este código de ejemplo, se ha utilizado la siguientes tablas:

Tabla meses (simplemente contiene los 12 meses del año):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
CREATE TABLE IF NOT EXISTS `meses` (
  `mes` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
INSERT INTO `meses` (`mes`) VALUES
(1),
(2),
(3),
(4),
(5),
(6),
(7),
(8),
(9),
(10),
(11),
(12);

Tabla pagos (donde se guardan los pagos que va realizando cada cliente):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
CREATE TABLE IF NOT EXISTS `pagos` (
  `pagosId` int(11) NOT NULL,
  `fechaPago` date NOT NULL,
  `clientes_idcliente` int(11) NOT NULL
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
 
INSERT INTO `pagos` (`pagosId`, `fechaPago`, `clientes_idcliente`) VALUES
(1, '2016-02-09', 1),
(2, '2016-03-09', 1),
(3, '2016-04-09', 1),
(4, '2016-05-09', 1),
(5, '2016-06-09', 1),
(6, '2016-09-09', 1),
(7, '2016-09-06', 2),
(8, '2016-10-06', 2),
(9, '2016-11-06', 2),
(10, '2016-12-06', 2);
1
2
3
4
5
6
7
8
9
# en este consulta, buscamos los meses no pagados por el cliente 1 y el año 2016
 
SELECT m.mes as mesesNoPagados FROM
 
(SELECT * FROM pagos WHERE clientes_idcliente=1 AND YEAR(fechaPago)=2016) s1
 
RIGHT JOIN meses m ON m.mes=month(s1.fechaPago)
 
WHERE pagosId is NULL



Comentarios sobre la versión: Versión 1.0 (1)

Luis
10 de Febrero del 2017
estrellaestrellaestrellaestrellaestrella
muchas gracias.
tengo que crear una tabla llamada "meses", a hace nomas le voy a insertar los 12. nada mas..
y luego creo una tabla llamada "Pagos".

Pera la consulta estas mencionando otra tabla llamada "mesesNoPagados ".
SELECT m.mes as mesesNoPagados FROM.


ya esta terminada la cosulta
Responder

Comentar la versión: Versión 1.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios

http://lwp-l.com/s3860