Difference between revisions of "VbzCart/queries/qryRstkItms expected"

from HTYP, the free directory anyone can edit if they can prove to me that they're not a spambot
Jump to navigation Jump to search
(discarded)
 
(5 intermediate revisions by the same user not shown)
Line 1: Line 1:
==Details==
+
==About==
* '''Returns''': Restock items requested, not yet received, but possibly expected because the restock request hasn't been closed or orphaned.
+
* '''Returns''': Restock items requested (ordered), not yet received, but possibly expected because the restock request hasn't been terminated (closed, orphaned, or killed).
 
* '''Requires''': {{vbzcart/table|rstk_rcd_line}}, {{vbzcart/table|rstk_rcd}}, {{vbzcart/query|qryRstkItms_active}}
 
* '''Requires''': {{vbzcart/table|rstk_rcd_line}}, {{vbzcart/table|rstk_rcd}}, {{vbzcart/query|qryRstkItms_active}}
 +
* '''Used by''': {{vbzcart/query|qryRstkItms_expected_byItem}}
 +
* '''Algorithm''': any positive quantities in '''<'''{{vbzcart/query|qryRstkItms_active|<all items in <active restock requests>>}} - <{{vbzcart|table|rstk_rcd_line|items received}} on those item requests>'''>'''
 
* '''History''':
 
* '''History''':
 
** '''2008-11-19''' Created for new restock process
 
** '''2008-11-19''' Created for new restock process
 
** '''2008-11-24''' '''QtyRecd''' falls back on '''QtyFiled''' if null
 
** '''2008-11-24''' '''QtyRecd''' falls back on '''QtyFiled''' if null
 +
** '''2008-12-04''' renamed: qryRstkItms_en_route → qryRstkItms_expected
 +
** '''2010-01-03''' fixed syntax: have to recalculate aggregate functions to use them in a HAVING clause (bleh)
 +
** '''2010-01-04''' updated to use QtyExp instead of QtyOrd (field renamed/changed in {{vbzcart/query|qryRstkItms_active}})
 +
** '''2016-03-02''' Query no longer works; removing from database.
 
==SQL==
 
==SQL==
<section begin=sql /><mysql>CREATE OR REPLACE VIEW qryRstkItms_en_route AS
+
<mysql>CREATE OR REPLACE VIEW qryRstkItms_expected AS
 
SELECT
 
SELECT
 
   rqi.ID_Restock,
 
   rqi.ID_Restock,
 
   rqi.ID_Item,
 
   rqi.ID_Item,
   SUM(rqi.QtyOrd) AS QtyOrd,
+
   SUM(rqi.QtyExp) AS QtyExp,
 
   SUM(IFNULL(rcl.QtyRecd,rcl.QtyFiled)) AS QtyRecd
 
   SUM(IFNULL(rcl.QtyRecd,rcl.QtyFiled)) AS QtyRecd
 
FROM
 
FROM
Line 17: Line 23:
 
     LEFT JOIN qryRstkItms_active AS rqi ON (rc.ID_Restock=rqi.ID_Restock) AND (rcl.ID_Item=rqi.ID_Item)
 
     LEFT JOIN qryRstkItms_active AS rqi ON (rc.ID_Restock=rqi.ID_Restock) AND (rcl.ID_Item=rqi.ID_Item)
 
GROUP BY rqi.ID_Restock, rqi.ID_Item
 
GROUP BY rqi.ID_Restock, rqi.ID_Item
HAVING IFNULL(QtyOrd,0)-IFNULL(QtyRecd,0);</mysql>
+
HAVING (SUM(rqi.QtyExp)-SUM(IFNULL(rcl.QtyRecd,rcl.QtyFiled)))>0;</mysql>
<section end=sql />
 

Latest revision as of 22:56, 2 March 2016

About

  • Returns: Restock items requested (ordered), not yet received, but possibly expected because the restock request hasn't been terminated (closed, orphaned, or killed).
  • Requires:
  1. REDIRECT Template:l/vc/table, rstk_rcd,
  2. REDIRECT Template:l/vc/query
  • Used by: qryRstkItms_expected_byItem
  • Algorithm: any positive quantities in <<all items in <active restock requests>> - <items received on those item requests>>
  • History:
    • 2008-11-19 Created for new restock process
    • 2008-11-24 QtyRecd falls back on QtyFiled if null
    • 2008-12-04 renamed: qryRstkItms_en_route → qryRstkItms_expected
    • 2010-01-03 fixed syntax: have to recalculate aggregate functions to use them in a HAVING clause (bleh)
    • 2010-01-04 updated to use QtyExp instead of QtyOrd (field renamed/changed in qryRstkItms_active)
    • 2016-03-02 Query no longer works; removing from database.

SQL

<mysql>CREATE OR REPLACE VIEW qryRstkItms_expected AS SELECT

 rqi.ID_Restock,
 rqi.ID_Item,
 SUM(rqi.QtyExp) AS QtyExp,
 SUM(IFNULL(rcl.QtyRecd,rcl.QtyFiled)) AS QtyRecd

FROM

 (rstk_rcd_line AS rcl
   LEFT JOIN rstk_rcd AS rc ON rcl.ID_RstkRcd=rc.ID)
   LEFT JOIN qryRstkItms_active AS rqi ON (rc.ID_Restock=rqi.ID_Restock) AND (rcl.ID_Item=rqi.ID_Item)

GROUP BY rqi.ID_Restock, rqi.ID_Item HAVING (SUM(rqi.QtyExp)-SUM(IFNULL(rcl.QtyRecd,rcl.QtyFiled)))>0;</mysql>