152 lines
4.9 KiB
SQL
152 lines
4.9 KiB
SQL
USE `vn`;
|
|
DROP procedure IF EXISTS `ticketGetProblems`;
|
|
|
|
DELIMITER $$
|
|
USE `vn`$$
|
|
CREATE DEFINER=`root`@`%` PROCEDURE `ticketGetProblems`()
|
|
BEGIN
|
|
/*
|
|
* Obtiene los problemas de uno o varios tickets
|
|
*
|
|
* @table tmp.ticketGetProblems(ticketFk, clientFk, warehouseFk, shipped)
|
|
* @return tmp.ticketProblems
|
|
*/
|
|
DECLARE vWarehouse INT;
|
|
DECLARE vDate DATE;
|
|
DECLARE vAvailableCache INT;
|
|
DECLARE vVisibleCache INT;
|
|
DECLARE vDone INT DEFAULT 0;
|
|
|
|
DECLARE vCursor CURSOR FOR
|
|
SELECT DISTINCT tt.warehouseFk, date(tt.shipped)
|
|
FROM tmp.ticketGetProblems tt
|
|
WHERE DATE(tt.shipped) BETWEEN CURDATE()
|
|
AND TIMESTAMPADD(DAY, 1.9, CURDATE());
|
|
|
|
DECLARE CONTINUE HANDLER FOR NOT FOUND SET vDone = 1;
|
|
|
|
DROP TEMPORARY TABLE IF EXISTS tmp.ticketProblems;
|
|
CREATE TEMPORARY TABLE tmp.ticketProblems (
|
|
ticketFk INT(11),
|
|
problem VARCHAR(50),
|
|
INDEX (ticketFk)
|
|
)
|
|
ENGINE = MEMORY;
|
|
|
|
-- CONGELADO
|
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
|
SELECT DISTINCT tt.ticketFk, 'Freezed'
|
|
FROM tmp.ticketGetProblems tt
|
|
JOIN vn.client c ON c.id = tt.clientFk
|
|
WHERE c.isFreezed;
|
|
|
|
-- eliminamos tickets con problemas para no volverlos a mirar
|
|
DROP TEMPORARY TABLE IF EXISTS tmp.ticketListFiltered;
|
|
|
|
CREATE TEMPORARY TABLE tmp.ticketListFiltered
|
|
(PRIMARY KEY (ticketFk))
|
|
ENGINE = MEMORY
|
|
SELECT tt.ticketFk, c.id
|
|
FROM tmp.ticketGetProblems tt
|
|
JOIN vn.client c ON c.id = tt.clientFk
|
|
WHERE c.isFreezed = 0;
|
|
|
|
DROP TEMPORARY TABLE IF EXISTS tmp.clientGetDebt;
|
|
CREATE TEMPORARY TABLE tmp.clientGetDebt
|
|
(PRIMARY KEY (clientFk))
|
|
ENGINE = MEMORY
|
|
SELECT DISTINCT tt.clientFk
|
|
FROM tmp.ticketGetProblems tt;
|
|
|
|
-- RIESGO
|
|
CALL clientGetDebt(CURDATE());
|
|
|
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
|
SELECT DISTINCT tt.ticketFk, 'Risk'
|
|
FROM tmp.ticketListFiltered tt
|
|
JOIN vn.ticket t ON t.id = tt.ticketFk
|
|
JOIN vn.agencyMode a ON t.agencyModeFk = a.id
|
|
JOIN tmp.risk r ON r.clientFk = t.clientFk
|
|
JOIN vn.client c ON c.id = t.clientFk
|
|
WHERE r.risk > c.credit + 10
|
|
AND a.deliveryMethodFk != 3; -- para que las recogidas se preparen
|
|
|
|
-- eliminamos tickets con problemas para no volverlos a mirar
|
|
DELETE tlf FROM tmp.ticketListFiltered tlf
|
|
JOIN tmp.ticketProblems tp ON tlf.ticketFk = tp.ticketFk;
|
|
|
|
-- CODIGO 100
|
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
|
SELECT DISTINCT tt.ticketFk, 'Code 100'
|
|
FROM tmp.ticketGetProblems tt
|
|
JOIN sale s ON s.ticketFk = tt.ticketFk
|
|
WHERE s.itemFk = 100;
|
|
|
|
-- eliminamos tickets con problemas para no volverlos a mirar
|
|
DELETE tlf FROM tmp.ticketListFiltered tlf
|
|
JOIN tmp.ticketProblems tp ON tlf.ticketFk = tp.ticketFk;
|
|
|
|
OPEN vCursor;
|
|
|
|
WHILE NOT vDone
|
|
DO
|
|
FETCH vCursor INTO vWarehouse, vDate;
|
|
|
|
CALL cache.visible_refresh(vVisibleCache, FALSE, vWarehouse);
|
|
CALL cache.available_refresh(vAvailableCache, FALSE, vWarehouse, vDate);
|
|
|
|
-- El disponible es menor que 0
|
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
|
SELECT tt.ticketFk, i.name
|
|
FROM tmp.ticketListFiltered tt
|
|
JOIN vn.ticket t ON t.id = tt.ticketFk
|
|
LEFT JOIN vn.sale s ON s.ticketFk = t.id
|
|
JOIN vn.item i ON i.id = s.itemFk
|
|
JOIN vn.itemType it on it.id = i.typeFk
|
|
LEFT JOIN cache.visible v ON i.id = v.item_id
|
|
AND v.calc_id = vVisibleCache
|
|
LEFT JOIN cache.available av ON av.item_id = i.id
|
|
AND av.calc_id = vAvailableCache
|
|
WHERE date(t.shipped) = vDate
|
|
AND categoryFk != 6
|
|
AND s.quantity > IFNULL(v.visible, 0)
|
|
AND IFNULL(av.available, 0) < 0
|
|
AND s.isPicked = FALSE
|
|
AND NOT i.generic
|
|
AND vWarehouse = t.warehouseFk;
|
|
|
|
-- eliminamos tickets con problemas para no volverlos a mirar
|
|
DELETE tlf FROM tmp.ticketListFiltered tlf
|
|
JOIN tmp.ticketProblems tp ON tlf.ticketFk = tp.ticketFk;
|
|
|
|
-- Amarillo: El disponible es mayor que cero y la cantidad supera el visible, estando aun sin preparar
|
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
|
SELECT tt.ticketFk, CONCAT('Delay', i.name)
|
|
FROM tmp.ticketListFiltered tt
|
|
JOIN vn.ticket t ON t.id = tt.ticketFk
|
|
LEFT JOIN vn.sale s ON s.ticketFk = t.id
|
|
JOIN vn.item i ON i.id = s.itemFk
|
|
JOIN vn.itemType it on it.id = i.typeFk
|
|
LEFT JOIN cache.visible v ON i.id = v.item_id AND v.calc_id = vVisibleCache
|
|
LEFT JOIN cache.available av ON av.item_id = i.id AND av.calc_id = vAvailableCache
|
|
WHERE IFNULL(av.available, 0) >= 0
|
|
AND s.quantity > IFNULL(v.visible, 0)
|
|
AND s.isPicked = FALSE
|
|
AND s.reserved = FALSE
|
|
AND it.categoryFk != 6
|
|
AND date(t.shipped) = vDate
|
|
AND NOT i.generic
|
|
AND CURDATE() = vDate
|
|
AND t.warehouseFk = vWarehouse;
|
|
END WHILE;
|
|
|
|
CLOSE vCursor;
|
|
|
|
DROP TEMPORARY TABLE
|
|
tmp.clientGetDebt,
|
|
tmp.ticketListFiltered;
|
|
END$$
|
|
|
|
DELIMITER ;
|
|
|