2024-01-15 11:31:03 +00:00
|
|
|
DELIMITER $$
|
|
|
|
CREATE OR REPLACE DEFINER=`root`@`localhost` PROCEDURE `bs`.`waste_addSales`()
|
|
|
|
BEGIN
|
2024-07-09 09:56:32 +00:00
|
|
|
CALL cache.last_buy_refresh (FALSE);
|
|
|
|
|
2024-01-15 11:31:03 +00:00
|
|
|
REPLACE bs.waste
|
2024-05-10 08:01:46 +00:00
|
|
|
SELECT YEAR(t.shipped),
|
|
|
|
WEEK(t.shipped, 4),
|
|
|
|
it.workerFk,
|
|
|
|
it.id,
|
|
|
|
s.itemFk,
|
|
|
|
SUM(s.quantity),
|
2024-07-09 10:00:55 +00:00
|
|
|
SUM((b.buyingValue + b.freightValue + b.comissionValue + b.packageValue) * s.quantity) `value`,
|
2024-05-10 08:01:46 +00:00
|
|
|
SUM (
|
|
|
|
IF(
|
2024-07-09 09:56:32 +00:00
|
|
|
aw.`type` = 'internal',
|
2024-05-10 08:01:46 +00:00
|
|
|
(b.buyingValue + b.freightValue + b.comissionValue + b.packageValue) * s.quantity,
|
|
|
|
0
|
|
|
|
)
|
|
|
|
) internalWaste,
|
|
|
|
SUM (
|
|
|
|
IF(
|
2024-07-09 09:56:32 +00:00
|
|
|
aw.`type` = 'external',
|
2024-05-10 08:01:46 +00:00
|
|
|
(b.buyingValue + b.freightValue + b.comissionValue + b.packageValue) * s.quantity,
|
2024-05-10 11:20:15 +00:00
|
|
|
IF(c.code = 'manaClaim',
|
|
|
|
sc.value * s.quantity,
|
|
|
|
0
|
|
|
|
)
|
2024-05-10 08:01:46 +00:00
|
|
|
)
|
|
|
|
) externalWaste
|
|
|
|
FROM vn.sale s
|
|
|
|
JOIN vn.item i ON i.id = s.itemFk
|
|
|
|
JOIN vn.itemType it ON it.id = i.typeFk
|
|
|
|
JOIN vn.ticket t ON t.id = s.ticketFk
|
2024-07-09 09:56:32 +00:00
|
|
|
JOIN vn.address a FORCE INDEX (PRIMARY) ON a.id = t.addressFk
|
2024-07-09 09:40:24 +00:00
|
|
|
LEFT JOIN vn.addressWaste aw ON aw.addressFk = a.id
|
2024-05-10 08:01:46 +00:00
|
|
|
JOIN vn.warehouse w ON w.id = t.warehouseFk
|
|
|
|
JOIN cache.last_buy lb ON lb.item_id = i.id
|
|
|
|
AND lb.warehouse_id = w.id
|
|
|
|
JOIN vn.buy b ON b.id = lb.buy_id
|
2024-07-09 09:43:15 +00:00
|
|
|
LEFT JOIN vn.saleComponent sc ON sc.saleFk = s.id
|
|
|
|
LEFT JOIN vn.component c ON c.id = sc.componentFk
|
2024-05-10 08:01:46 +00:00
|
|
|
WHERE w.isManaged
|
|
|
|
AND YEAR(t.shipped) = YEAR(util.VN_CURDATE())
|
|
|
|
AND WEEK(t.shipped, 4) = WEEK(util.VN_CURDATE(), 4)
|
2024-05-10 11:20:15 +00:00
|
|
|
GROUP BY it.id, i.id;
|
2024-01-15 11:31:03 +00:00
|
|
|
END$$
|
|
|
|
DELIMITER ;
|