60 lines
1.8 KiB
SQL
60 lines
1.8 KiB
SQL
DELIMITER $$
|
|
CREATE OR REPLACE DEFINER=`vn`@`localhost` PROCEDURE `vn`.`zone_getAddresses`(
|
|
vSelf INT,
|
|
vLanded DATE,
|
|
vDepartmentFk INT
|
|
)
|
|
BEGIN
|
|
/**
|
|
* Devuelve un listado de todos los clientes activos
|
|
* con consignatarios a los que se les puede
|
|
* entregar producto para esa zona.
|
|
*
|
|
* @param vSelf Id de zona
|
|
* @param vLanded Fecha de entrega
|
|
* @param vDepartmentFk Id de departamento | NULL para mostrar todos
|
|
* @return Un select
|
|
*/
|
|
CALL zone_getPostalCode(vSelf);
|
|
|
|
WITH clientWithTicket AS (
|
|
SELECT DISTINCT clientFk
|
|
FROM vn.ticket
|
|
WHERE landed BETWEEN vLanded AND util.dayEnd(vLanded)
|
|
AND NOT isDeleted
|
|
)
|
|
SELECT c.id,
|
|
c.name,
|
|
c.phone,
|
|
bt.description,
|
|
c.salesPersonFk,
|
|
u.name username,
|
|
aai.invoiced,
|
|
cnb.lastShipped,
|
|
IF(cwt.clientFk, TRUE, FALSE) hasTicket
|
|
FROM vn.client c
|
|
JOIN vn.worker w ON w.id = c.salesPersonFk
|
|
JOIN vn.workerDepartment wd ON wd.workerFk = w.id
|
|
JOIN vn.department d ON d.id = wd.departmentFk
|
|
LEFT JOIN clientWithTicket cwt ON cwt.clientFk = c.id
|
|
LEFT JOIN account.`user` u ON u.id = c.salesPersonFk
|
|
JOIN vn.`address` a ON a.clientFk = c.id
|
|
JOIN vn.postCode pc ON pc.code = a.postalCode
|
|
JOIN vn.town t ON t.id = pc.townFk AND t.provinceFk = a.provinceFk
|
|
JOIN vn.zoneGeo zg ON zg.name = a.postalCode
|
|
JOIN tmp.zoneNodes zn ON zn.geoFk = pc.geoFk
|
|
LEFT JOIN bs.clientNewBorn cnb ON cnb.clientFk = c.id
|
|
LEFT JOIN vn.annualAverageInvoiced aai ON aai.clientFk = c.id
|
|
JOIN vn.clientType ct ON ct.code = c.typeFk
|
|
JOIN vn.businessType bt ON bt.code = c.businessTypeFk
|
|
WHERE a.isActive
|
|
AND c.isActive
|
|
AND ct.code = 'normal'
|
|
AND bt.code <> 'worker'
|
|
AND (d.id = vDepartmentFk OR vDepartmentFk IS NULL)
|
|
GROUP BY c.id;
|
|
|
|
DROP TEMPORARY TABLE tmp.zoneNodes;
|
|
END$$
|
|
DELIMITER ;
|