Again optimizations for #384

This commit is contained in:
Bernd Bestel 2019-09-26 13:13:49 +02:00
parent 2809cc1454
commit 45d3c25b21
No known key found for this signature in database
GPG Key ID: 71BD34C0D4891300

View File

@ -1,33 +1,40 @@
ALTER TABLE products ALTER TABLE products
ADD cumulate_min_stock_amount_of_sub_products TINYINT DEFAULT 0; ADD cumulate_min_stock_amount_of_sub_products TINYINT DEFAULT 0;
CREATE VIEW products_view
AS
SELECT *, CASE WHEN (SELECT 1 FROM products WHERE parent_product_id = p.id) NOTNULL THEN 1 ELSE 0 END AS has_sub_products
FROM products p;
DROP VIEW stock_missing_products; DROP VIEW stock_missing_products;
CREATE VIEW stock_missing_products CREATE VIEW stock_missing_products
AS AS
-- Parent products where the amount of the sub products SHOULD NOT be cumulated -- Products WITHOUT sub products where the amount of the sub products SHOULD NOT be cumulated
SELECT SELECT
p.id, p.id,
MAX(p.name) AS name, MAX(p.name) AS name,
p.min_stock_amount - IFNULL(SUM(s.amount), 0) AS amount_missing, p.min_stock_amount - IFNULL(SUM(s.amount), 0) AS amount_missing,
CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock
FROM products p FROM products_view p
LEFT JOIN stock_current s LEFT JOIN stock_current s
ON p.id = s.product_id ON p.id = s.product_id
WHERE p.min_stock_amount != 0 WHERE p.min_stock_amount != 0
AND p.cumulate_min_stock_amount_of_sub_products = 0 AND p.cumulate_min_stock_amount_of_sub_products = 0
AND p.has_sub_products = 0
AND p.parent_product_id IS NULL
GROUP BY p.id GROUP BY p.id
HAVING IFNULL(SUM(s.amount), 0) < p.min_stock_amount HAVING IFNULL(SUM(s.amount), 0) < p.min_stock_amount
UNION UNION
-- Parent products where the amount of the sub products SHOULD be cumulated -- Parent products WITH sub products where the amount of the sub products SHOULD be cumulated
SELECT SELECT
p.id, p.id,
MAX(p.name) AS name, MAX(p.name) AS name,
SUM(sub_p.min_stock_amount) - IFNULL(SUM(s.amount), 0) AS amount_missing, SUM(sub_p.min_stock_amount) - IFNULL(SUM(s.amount), 0) AS amount_missing,
CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock
FROM products p FROM products_view p
JOIN products_resolved pr JOIN products_resolved pr
ON p.id = pr.parent_product_id ON p.id = pr.parent_product_id
JOIN products sub_p JOIN products sub_p
@ -65,29 +72,31 @@ AS
/* This is basically the same view as stock_missing_products, but the column "amount_missing" includes opened amounts */ /* This is basically the same view as stock_missing_products, but the column "amount_missing" includes opened amounts */
-- Parent products where the amount of the sub products SHOULD NOT be cumulated -- Products WITHOUT sub products where the amount of the sub products SHOULD NOT be cumulated
SELECT SELECT
p.id, p.id,
MAX(p.name) AS name, MAX(p.name) AS name,
p.min_stock_amount - (IFNULL(SUM(s.amount), 0) - IFNULL(SUM(s.amount_opened), 0)) AS amount_missing, p.min_stock_amount - (IFNULL(SUM(s.amount), 0) - IFNULL(SUM(s.amount_opened), 0)) AS amount_missing,
CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock
FROM products p FROM products_view p
LEFT JOIN stock_current s LEFT JOIN stock_current s
ON p.id = s.product_id ON p.id = s.product_id
WHERE p.min_stock_amount != 0 WHERE p.min_stock_amount != 0
AND p.cumulate_min_stock_amount_of_sub_products = 0 AND p.cumulate_min_stock_amount_of_sub_products = 0
AND p.has_sub_products = 0
AND p.parent_product_id IS NULL
GROUP BY p.id GROUP BY p.id
HAVING IFNULL(SUM(s.amount), 0) < p.min_stock_amount HAVING IFNULL(SUM(s.amount), 0) < p.min_stock_amount
UNION UNION
-- Parent products where the amount of the sub products SHOULD be cumulated -- Parent products WITH sub products where the amount of the sub products SHOULD be cumulated
SELECT SELECT
p.id, p.id,
MAX(p.name) AS name, MAX(p.name) AS name,
SUM(sub_p.min_stock_amount) - (IFNULL(SUM(s.amount), 0) - IFNULL(SUM(s.amount_opened), 0)) AS amount_missing, SUM(sub_p.min_stock_amount) - (IFNULL(SUM(s.amount), 0) - IFNULL(SUM(s.amount_opened), 0)) AS amount_missing,
CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock CASE WHEN IFNULL(SUM(s.amount), 0) > 0 THEN 1 ELSE 0 END AS is_partly_in_stock
FROM products p FROM products_view p
JOIN products_resolved pr JOIN products_resolved pr
ON p.id = pr.parent_product_id ON p.id = pr.parent_product_id
JOIN products sub_p JOIN products sub_p