vault backup: 2023-11-03 11:00:54

This commit is contained in:
Paul Trowbridge 2023-11-03 11:00:54 -04:00
parent 0be561a7f2
commit 2fe17ac58c
2 changed files with 88 additions and 31 deletions

View File

@ -1,46 +1,61 @@
WITH WITH
--getj AS ( getj AS (
-- SELECT SELECT
-- jsonb_build_object('mold',stlc) doc (
-- FROM SELECT
-- "CMS.CUSLG".itemm jsonb_build_object('mold',JSON_AGG(DISTINCT stlc)) doc
-- WHERE FROM
-- item = $1 "CMS.CUSLG".itemm
--) WHERE
agg AS ( item ~ 'TUH10000A10B04'
) ||
(
SELECT
jsonb_build_object('cust',JSONB_AGG(DISTINCT c.dba))
FROM
rlarp.cust c
WHERE
c.dba ~ 'DIAMOND R'
) doc
)
,agg AS (
SELECT SELECT
gset gset
,agglevel ,(SELECT string_agg(ae.v,'.') FROM jsonb_array_elements_text(p.agglevel) ae(v)) agglvl
,season ,season
,(select doc from getj) gdoc
FROM FROM
rlarp.price_pool_dev rlarp.price_pool_dev p
WHERE WHERE
--gset @> '{"mold":"XNS0T1G3"}'::jsonb --gut the exact mold and actuals only
gset @> jsonb_build_object( gset @> jsonb_build_object(
'mold','TUH10000', 'mold',(SELECT doc->'mold'->>0 FROM getj),
'vers','A' 'vers','A'
) )
--pull either the exact customer or no customer
AND ( AND (
gset->>'cust' ~ 'DIAMOND' gset @> jsonb_build_object(
'cust',(SELECT doc->'cust'->>0 FROM getj)
)
OR NOT gset ? 'cust' OR NOT gset ? 'cust'
) )
ORDER BY ORDER BY
agglevel ASC agglevel ASC
) )
SELECT ,final AS (
jsonb_build_object('agg',agglevel ) SELECT
|| jsonb_build_object( jsonb_build_object(
agg.agglvl,
jsonb_build_object(
'data', 'data',
jsonb_agg(gset || jsonb_build_object('season',season)) jsonb_agg(gset || jsonb_build_object('season',season))
)
) data ) data
FROM ,gdoc
FROM
agg agg
GROUP BY GROUP BY
agglevel agglvl
LIMIT 10 ,gdoc
--SELECT )
-- jsonb_pretty(agglevel) agglevel select * from final
-- ,jsonb_pretty(gset) gset
-- ,jsonb_pretty(season) season
--FROM
-- agg

42
sql/guidance.pg.sql Normal file
View File

@ -0,0 +1,42 @@
CREATE OR REPLACE FUNCTION rlarp.guidancejsd(_p jsonb, cust text, prod text)
RETURNS jsonb
LANGUAGE plv8
AS $function$
function findMostRecentPrice(data, cust, prod) {
let mostRecentPrice = null;
let mostRecentYear = null;
// Iterate through each product
data.forEach(product => {
// Check if the product matches the customer channel and version
if (product.chan === cust && (product.v1ds === prod || product.v0ds === prod)) {
// Iterate through the seasons for the product
for (let year in product.season) {
// Convert year to number for comparison
let yearNum = parseInt(year);
// Check if this year is more recent than the current most recent year
if (mostRecentYear === null || yearNum > mostRecentYear) {
mostRecentYear = yearNum;
// Update the most recent price
mostRecentPrice = product.season[year].price_usd;
}
}
}
});
return mostRecentPrice;
}
// Example usage:
const jsonData = _p;
const cust = 'W'; // or 'D', depending on the customer
const prod = 'TUH10000'; // the product version you're interested in
const price = findMostRecentPrice(jsonData.data, cust, prod);
console.log(`The most recent price for the customer is: ${price}`);
return price;
$function$;