udate structure db
This commit is contained in:
parent
35d4c99e53
commit
b9dd605c77
|
@ -1,70 +0,0 @@
|
||||||
USE `vn`;
|
|
||||||
DROP procedure IF EXISTS `ticketGetTax`;
|
|
||||||
|
|
||||||
DELIMITER $$
|
|
||||||
USE `vn`$$
|
|
||||||
CREATE DEFINER=`root`@`%` PROCEDURE `ticketGetTax`()
|
|
||||||
READS SQL DATA
|
|
||||||
BEGIN
|
|
||||||
/**
|
|
||||||
* Calcula la base imponible, el IVA y el recargo de equivalencia para
|
|
||||||
* un conjunto de tickets.
|
|
||||||
*
|
|
||||||
* @table tmp.ticket(ticketFk) Identificadores de los tickets a calcular
|
|
||||||
* @return tmp.ticketTax Impuesto desglosado para cada ticket
|
|
||||||
* @return tmp.ticketAmount
|
|
||||||
*/
|
|
||||||
DROP TEMPORARY TABLE IF EXISTS tmp.addressCompany;
|
|
||||||
CREATE TEMPORARY TABLE tmp.addressCompany
|
|
||||||
(INDEX (addressFk, companyFk))
|
|
||||||
ENGINE = MEMORY
|
|
||||||
SELECT DISTINCT t.addressFk, t.companyFk
|
|
||||||
FROM tmp.ticket tmpTicket
|
|
||||||
JOIN ticket t ON t.id = tmpTicket.ticketFk;
|
|
||||||
|
|
||||||
|
|
||||||
CALL addressTaxArea ();
|
|
||||||
|
|
||||||
DROP TEMPORARY TABLE IF EXISTS tmp.ticketTax;
|
|
||||||
CREATE TEMPORARY TABLE tmp.ticketTax
|
|
||||||
(INDEX (ticketFk))
|
|
||||||
ENGINE = MEMORY
|
|
||||||
SELECT tmpTicket.ticketFk,
|
|
||||||
bp.pgcFk,
|
|
||||||
ROUND(SUM(s.quantity * s.price * (100 - s.discount)/100
|
|
||||||
),2) AS taxableBase,
|
|
||||||
ROUND(SUM(s.quantity * s.price * (100 - s.discount)/100
|
|
||||||
) * pgc.rate / 100,2) AS tax,
|
|
||||||
tc.code
|
|
||||||
FROM tmp.ticket tmpTicket
|
|
||||||
JOIN sale s ON s.ticketFk = tmpTicket.ticketFk
|
|
||||||
JOIN item i ON i.id = s.itemFk
|
|
||||||
JOIN ticket t ON t.id = tmpTicket.ticketFk
|
|
||||||
JOIN supplier su ON su.id = t.companyFk
|
|
||||||
JOIN tmp.addressTaxArea ata
|
|
||||||
ON ata.addressFk = t.addressFk AND ata.companyFk = t.companyFk
|
|
||||||
JOIN itemTaxCountry itc
|
|
||||||
ON itc.itemFk = i.id AND itc.countryFk = su.countryFk
|
|
||||||
JOIN bookingPlanner bp
|
|
||||||
ON bp.countryFk = su.countryFk
|
|
||||||
AND bp.taxAreaFk = ata.areaFk
|
|
||||||
AND bp.taxClassFk = itc.taxClassFk
|
|
||||||
JOIN pgc ON pgc.code = bp.pgcFk
|
|
||||||
JOIN taxClass tc ON tc.id = bp.taxClassFk
|
|
||||||
GROUP BY tmpTicket.ticketFk, pgc.code
|
|
||||||
HAVING taxableBase != 0;
|
|
||||||
|
|
||||||
DROP TEMPORARY TABLE IF EXISTS tmp.ticketAmount;
|
|
||||||
CREATE TEMPORARY TABLE tmp.ticketAmount
|
|
||||||
(INDEX (ticketFk))
|
|
||||||
ENGINE = MEMORY
|
|
||||||
SELECT ticketFk, taxableBase, SUM(tax) tax
|
|
||||||
FROM tmp.ticketTax
|
|
||||||
GROUP BY ticketFk, code;
|
|
||||||
|
|
||||||
DROP TEMPORARY TABLE IF EXISTS tmp.addressCompany;
|
|
||||||
DROP TEMPORARY TABLE IF EXISTS tmp.addressTaxArea;
|
|
||||||
END$$
|
|
||||||
|
|
||||||
DELIMITER ;
|
|
||||||
|
|
|
@ -0,0 +1,147 @@
|
||||||
|
USE `vn`;
|
||||||
|
DROP procedure IF EXISTS `ticketGetProblems`;
|
||||||
|
|
||||||
|
DELIMITER $$
|
||||||
|
USE `vn`$$
|
||||||
|
CREATE DEFINER=`root`@`%` PROCEDURE `ticketGetProblems`()
|
||||||
|
BEGIN
|
||||||
|
|
||||||
|
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) PRIMARY KEY,
|
||||||
|
problem VARCHAR(50)
|
||||||
|
) ENGINE = MEMORY;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.ticketList;
|
||||||
|
CREATE TEMPORARY TABLE tmp.ticketList
|
||||||
|
(PRIMARY KEY (ticketFk))
|
||||||
|
ENGINE = MEMORY
|
||||||
|
SELECT tp.ticketFk, c.id clientFk
|
||||||
|
FROM tmp.ticketGetProblems tp
|
||||||
|
JOIN vn.client c ON c.id = tp.clientFk;
|
||||||
|
|
||||||
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
||||||
|
SELECT DISTINCT tl.ticketFk, 'Freezed'
|
||||||
|
FROM tmp.ticketList tl
|
||||||
|
JOIN vn.client c ON c.id = tl.clientFk
|
||||||
|
WHERE c.isFreezed;
|
||||||
|
|
||||||
|
DELETE tl FROM tmp.ticketList tl
|
||||||
|
JOIN tmp.ticketProblems tp ON tl.ticketFk = tp.ticketFk;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE IF EXISTS tmp.clientGetDebt;
|
||||||
|
CREATE TEMPORARY TABLE tmp.clientGetDebt
|
||||||
|
(PRIMARY KEY (clientFk))
|
||||||
|
ENGINE = MEMORY
|
||||||
|
SELECT DISTINCT clientFk
|
||||||
|
FROM tmp.ticketList;
|
||||||
|
|
||||||
|
CALL clientGetDebt(CURDATE());
|
||||||
|
|
||||||
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
||||||
|
SELECT DISTINCT tl.ticketFk, 'Risk'
|
||||||
|
FROM tmp.ticketList tl
|
||||||
|
JOIN vn.ticket t ON t.id = tl.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;
|
||||||
|
|
||||||
|
|
||||||
|
DELETE tl FROM tmp.ticketList tl
|
||||||
|
JOIN tmp.ticketProblems tp ON tl.ticketFk = tp.ticketFk;
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
||||||
|
SELECT DISTINCT tl.ticketFk, 'Code 100'
|
||||||
|
FROM tmp.ticketList tl
|
||||||
|
JOIN vn.ticketRequest tr on tr.ticketFk = tl.ticketFk;
|
||||||
|
|
||||||
|
DELETE tl FROM tmp.ticketList tl
|
||||||
|
JOIN tmp.ticketProblems tp ON tl.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);
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
||||||
|
SELECT tl.ticketFk, i.name
|
||||||
|
FROM tmp.ticketList tl
|
||||||
|
JOIN vn.ticket t ON t.id = tl.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
|
||||||
|
GROUP BY tl.ticketFk;
|
||||||
|
|
||||||
|
|
||||||
|
DELETE tl FROM tmp.ticketList tl
|
||||||
|
JOIN tmp.ticketProblems tp ON tl.ticketFk = tp.ticketFk;
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO tmp.ticketProblems(ticketFk, problem)
|
||||||
|
SELECT tl.ticketFk, CONCAT('Delay', i.name)
|
||||||
|
FROM tmp.ticketList tl
|
||||||
|
JOIN vn.ticket t ON t.id = tl.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
|
||||||
|
GROUP BY tl.ticketFk;
|
||||||
|
|
||||||
|
|
||||||
|
DELETE tl FROM tmp.ticketList tl
|
||||||
|
JOIN tmp.ticketProblems tp ON tl.ticketFk = tp.ticketFk;
|
||||||
|
|
||||||
|
END WHILE;
|
||||||
|
|
||||||
|
CLOSE vCursor;
|
||||||
|
|
||||||
|
DROP TEMPORARY TABLE
|
||||||
|
tmp.clientGetDebt,
|
||||||
|
tmp.ticketList;
|
||||||
|
END$$
|
||||||
|
|
||||||
|
DELIMITER ;
|
||||||
|
|
Loading…
Reference in New Issue