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

<<>>
Imágen de perfil
Val: 796
Oro
Ha mantenido su posición en MySQL (en relación al último mes)
Gráfica de MySQL

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


MySQL

Publicado el 6 de Febrero del 2017 por Xve (294 códigos)
4.007 visualizaciones desde el 6 de Febrero del 2017
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 2 de Mayo del 2017 (Publicado el 6 de Febrero del 2017)gráfica de visualizaciones de la versión: Versión 1.0
4.008 visualizaciones desde el 6 de Febrero del 2017
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...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s3860