128 lines
3.9 KiB
SQL
128 lines
3.9 KiB
SQL
-- set work_mem TO '4GB';
|
|
--
|
|
DROP VIEW IF EXISTS rlarp.quote_review;
|
|
CREATE VIEW rlarp.quote_review AS
|
|
WITH
|
|
lq AS MATERIALIZED (
|
|
SELECT
|
|
lq.*
|
|
,substring(lq.part,1,8) mold
|
|
FROM
|
|
pricequote.live_quotes lq
|
|
)
|
|
,lqg AS (
|
|
SELECT
|
|
lq.qid
|
|
,lq.qline
|
|
,lq.rep
|
|
,lq.touched
|
|
,lq.expires
|
|
,lq.request
|
|
,lq.qtitle
|
|
,lq.qstatid
|
|
,lq.qstat
|
|
,lq.quotenumber
|
|
,lq.billto
|
|
,lq.shipto
|
|
,lq.qchan
|
|
,lq.qcustomer
|
|
,lq.part
|
|
,lq.qoptions
|
|
,lq.partbuilt
|
|
,lq.colgrp
|
|
,lq.colc
|
|
,lq.coltier
|
|
,lq.brand
|
|
,lq.dataseg
|
|
,lq.v1ds
|
|
,lq.comment
|
|
,lq.units_each
|
|
,lq.price
|
|
,lq.sales
|
|
,lq.histprice
|
|
,lq.targetp
|
|
,lq.lastsalesprice
|
|
,lq.r_curr
|
|
,lq.qt_rate
|
|
,lq.qrn
|
|
,lq.url
|
|
,lq.tacticalmodifier
|
|
,lq.finalrecommendedprice
|
|
,lq.lowerpricelimit
|
|
,lq.upperpricelimit
|
|
,(lq.upperpricelimit + lq.lowerpricelimit) / 2 midrange
|
|
,i.partgroup part_group
|
|
-- ,pricing->'product'->>'itemrel' item_fit
|
|
,i.mpck pltq
|
|
-- ,(pricing->'guidance'->'finalPrice'->>'Price')::numeric guidance
|
|
-- ,pricing->'guidance'->'finalPrice'->>'Reason' reason
|
|
,i.curstdus cstd_usd
|
|
,i.futstdus fstd_usd
|
|
,CASE
|
|
WHEN i.glec = '1NU' THEN
|
|
--if more than 8/24 pallets, use floor
|
|
CASE WHEN units_each >= 24*mpck THEN lq.lowerpricelimit
|
|
-- if more than a pallet use the target price
|
|
ELSE CASE WHEN units_each >= 8*mpck THEN (lq.upperpricelimit + lq.lowerpricelimit) / 2
|
|
-- if more than a pallet use the target price
|
|
ELSE CASE WHEN units_each < 8*mpck THEN lq.upperpricelimit
|
|
-- if more than a pallet use the target price
|
|
ELSE CASE WHEN units_each < mpck THEN lq.upperpricelimit * 1.15
|
|
END END END END
|
|
ELSE
|
|
--if more than 8/24 pallets, use floor
|
|
CASE WHEN units_each >= 08*mpck THEN lq.lowerpricelimit
|
|
-- if more than a pallet use the target price
|
|
ELSE CASE WHEN units_each >= 2*mpck THEN (lq.upperpricelimit + lq.lowerpricelimit) / 2
|
|
-- if more than a pallet use the target price
|
|
ELSE CASE WHEN units_each < 2*mpck THEN lq.upperpricelimit
|
|
-- if more than a pallet use the target price
|
|
ELSE CASE WHEN units_each < mpck THEN lq.upperpricelimit * 1.15
|
|
END END END END
|
|
END guidance
|
|
-- ,(pricing->'guidance'->>'ltp')::numeric ltp
|
|
-- ,(pricing->'guidance'->>'optimization')::numeric optimization
|
|
-- ,(pricing->'guidance'->>'inflationFactor')::numeric inflation
|
|
-- ,jsonb_pretty(pricing) pricing
|
|
FROM
|
|
lq
|
|
LEFT OUTER JOIN "CMS.CUSLG".itemm i ON
|
|
i.item = lq.part
|
|
WHERE
|
|
lq.qstat ~ 'Submitted'
|
|
)
|
|
,hist AS (
|
|
SELECT
|
|
g.*
|
|
,gset.chan
|
|
--,gset.mold moldh
|
|
,gset.v1ds v1dsh
|
|
,gset.cust
|
|
,gset.vers
|
|
,je.k
|
|
,seas.*
|
|
FROM
|
|
lqg g
|
|
LEFT OUTER JOIN rlarp.price_pool_dev p ON
|
|
p.gset @> jsonb_build_object('mold',g.part_group)
|
|
AND p.gset ? 'cust'
|
|
AND p.gset ? 'v1ds'
|
|
LEFT JOIN LATERAL jsonb_to_record(p.gset) AS gset(
|
|
chan text
|
|
,mold text
|
|
,v1ds text
|
|
,v0ds text
|
|
,cust text
|
|
,vers text
|
|
--,nurs text
|
|
--,ghse text
|
|
) ON TRUE
|
|
LEFT JOIN LATERAL jsonb_each(p.season) je(k,v) on true
|
|
LEFT JOIN Lateral jsonb_to_record(je.v) as seas(
|
|
units numeric
|
|
,sales_usd numeric
|
|
,price_usd numeric
|
|
) ON TRUE
|
|
)
|
|
SELECT * FROM hist --WHERE qid = 108596
|