VbzCart/docs/procs/Upd CatItems fr StkItems StkBins: Difference between revisions

From Woozle Writes Code
< VbzCart‎ | docs‎ | procs
Jump to navigation Jump to search
imported>Woozle
(corrected i.QtyInStock)
 
(One intermediate revision by one other user not shown)
Line 5: Line 5:
* '''History''':
* '''History''':
** '''2011-01-24''' Corrected '''i.QtyInStock''' to '''i.QtyIn_Stk'''
** '''2011-01-24''' Corrected '''i.QtyInStock''' to '''i.QtyIn_Stk'''
** '''2012-02-06''' Added "AND (sb.isEnabled)" condition (isEnabled flag is new)
==SQL==
==SQL==
<section begin=sql /><mysql>DROP PROCEDURE IF EXISTS `Upd_CatItems_fr_StkItems_StkBins`;
<section begin=sql /><mysql>DROP PROCEDURE IF EXISTS `Upd_CatItems_fr_StkItems_StkBins`;
Line 13: Line 14:
             SUM(si.Qty) AS QtyInStock
             SUM(si.Qty) AS QtyInStock
         FROM stk_items AS si LEFT JOIN stk_bins AS sb ON si.ID_Bin=sb.ID
         FROM stk_items AS si LEFT JOIN stk_bins AS sb ON si.ID_Bin=sb.ID
         WHERE (sb.isForSale) AND ISNULL(sb.WhenVoided) AND ISNULL(si.WhenRemoved)
         WHERE (sb.isForSale) AND (sb.isEnabled) AND ISNULL(sb.WhenVoided) AND ISNULL(si.WhenRemoved)
         GROUP BY ID_Item
         GROUP BY ID_Item
         ) AS sig ON i.ID=sig.ID_Item
         ) AS sig ON i.ID=sig.ID_Item

Latest revision as of 01:55, 25 February 2024

About

  • Action: updates availability from current stock
  • Input: Template:Vbzcart, Template:Vbzcart
  • Output: Template:Vbzcart
  • History:
    • 2011-01-24 Corrected i.QtyInStock to i.QtyIn_Stk
    • 2012-02-06 Added "AND (sb.isEnabled)" condition (isEnabled flag is new)

SQL

<section begin=sql /><mysql>DROP PROCEDURE IF EXISTS `Upd_CatItems_fr_StkItems_StkBins`; CREATE PROCEDURE Upd_CatItems_fr_StkItems_StkBins()

   UPDATE cat_items AS i LEFT JOIN (
       SELECT
           si.ID_Item,
           SUM(si.Qty) AS QtyInStock
        FROM stk_items AS si LEFT JOIN stk_bins AS sb ON si.ID_Bin=sb.ID
        WHERE (sb.isForSale) AND (sb.isEnabled) AND ISNULL(sb.WhenVoided) AND ISNULL(si.WhenRemoved)
        GROUP BY ID_Item
       ) AS sig ON i.ID=sig.ID_Item
     SET
        i.QtyIn_Stk = sig.QtyInStock,
        i.isForSale = i.isInPrint OR (sig.QtyInStock > 0);</mysql>

<section end=sql />