Compare commits

...

25 Commits

Author SHA1 Message Date
pt
b881fae5b4 Merge branch 'basket' of hc-companies/forecast_api into dev 2020-02-14 16:25:17 +00:00
pt
1b8c101429 update history log 2020-02-14 02:24:52 -05:00
pt
6e8f026770 forgot to swap out alias 2020-02-14 00:15:11 -05:00
Paul Trowbridge
8aeecc845b use materialized view of itemm and use date range object to facilitate join 2020-02-13 23:54:11 -05:00
Paul Trowbridge
8d1cd1ade6 functional but joining to itemm is very expensive 2020-02-13 17:29:13 -05:00
Trowbridge
acca526dca overhaul new basket 2020-02-13 16:41:39 -05:00
pt
07bd753a8e Merge branch 'heavy_mod' of hc-companies/forecast_api into dev 2020-02-13 19:21:23 +00:00
Trowbridge
0c394b2557 update CTE names, remove volume filter 2020-02-13 14:00:04 -05:00
Paul Trowbridge
b3122a50bb swap out return rows 2020-02-13 13:56:29 -05:00
Trowbridge
a4cf5b7607 insert new columns and log 2020-02-13 13:20:33 -05:00
Trowbridge
9793596d27 switch scale columns 2020-02-13 13:19:06 -05:00
Trowbridge
79ec4739c1 swap out basemix coluns 2020-02-13 13:18:55 -05:00
Trowbridge
a4d34ec83a add column names 2020-02-13 13:10:18 -05:00
Trowbridge
e49c051383 clean-up minor errors, running now 2020-02-13 13:08:02 -05:00
Trowbridge
f83746b892 swap out returning columns 2020-02-13 12:48:51 -05:00
Trowbridge
fb7fdc7959 swap out columns on price adjust 2020-02-13 12:47:25 -05:00
Trowbridge
5e4690a1f4 swap out value fields 2020-02-13 12:47:01 -05:00
Paul Trowbridge
ef914f3d5e insert to log and swap out columns on volume scale 2020-02-13 12:26:13 -05:00
Trowbridge
994b076321 swap out fb_qty or units 2020-02-13 12:21:30 -05:00
Trowbridge
610c78f36f swap out basemix columns 2020-02-13 12:19:45 -05:00
Paul Trowbridge
04276a89cb swap out iterdef with module, and point to osm_pool 2020-02-13 12:18:32 -05:00
Paul Trowbridge
21cb531e56 embed the module in the forecast pool instead of reading the json, cross join the newly inserted log file and id 2020-02-13 11:03:42 -05:00
pt
eddece49e1 start on scale_vd 2020-02-13 02:25:24 -05:00
pt
040ba4caf6 use copy not baseline, build log table 2020-02-13 02:25:02 -05:00
pt
d557fe9cc3 put the column names back 2020-02-13 01:11:51 -05:00
10 changed files with 1188 additions and 1950 deletions

236
index.js
View File

@ -18,8 +18,8 @@ var options = {
passprase: [] passprase: []
}; };
https.createServer(options,server).listen(process.env.nodeport, () => { https.createServer(options, server).listen(process.env.nodeport, () => {
console.log('started on '+ process.env.nodeport) console.log('started on ' + process.env.nodeport)
}); });
//server.listen(3000, () => console.log('started')) //server.listen(3000, () => console.log('started'))
@ -34,7 +34,7 @@ var Postgres = new pg.Client({
}); });
Postgres.connect(); Postgres.connect();
Postgres.FirstRow = function (inSQL, args, inResponse) { Postgres.FirstRow = function(inSQL, args, inResponse) {
Postgres.query(inSQL, args, (err, res) => { Postgres.query(inSQL, args, (err, res) => {
if (err === null) { if (err === null) {
inResponse.json(res.rows[0]); inResponse.json(res.rows[0]);
@ -55,14 +55,14 @@ server.get('/pgbadger', (req, res) => res.sendFile(process.env.wd + 'logs.html')
server.get('/totals', (req, res) => res.sendFile(process.env.wd + 'totals.log')) server.get('/totals', (req, res) => res.sendFile(process.env.wd + 'totals.log'))
server.get('/test_sql', function(req, res){ server.get('/test_sql', function(req, res) {
var path = './route_meta/scenario_package.sql' var path = './route_meta/scenario_package.sql'
var callback = function(arg){ var callback = function(arg) {
res.send(arg) res.send(arg)
}; };
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
callback(err); callback(err);
@ -70,21 +70,21 @@ server.get('/test_sql', function(req, res){
}); });
}); });
server.get('/get_pool', bodyParser.json(), function (req, res) { server.get('/get_pool', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var args = [req.body.quota_rep]; var args = [req.body.quota_rep];
var path = './route_sql/get_pool.sql'; var path = './route_sql/get_pool.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
console.log(new Date().toISOString() + "-------------------------get pool:----------------------------"); console.log(new Date().toISOString() + "-------------------------get pool:----------------------------");
console.log(req.body.quota_rep); console.log(req.body.quota_rep);
sql = sql.replace("rep_replace",req.body.quota_rep); sql = sql.replace("rep_replace", req.body.quota_rep);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
}; };
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -94,7 +94,7 @@ server.get('/get_pool', bodyParser.json(), function (req, res) {
}) })
server.get('/scenario_package', bodyParser.json(), function (req, res) { server.get('/scenario_package', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -103,8 +103,8 @@ server.get('/scenario_package', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/scenario_package.sql'; var path = './route_sql/scenario_package.sql';
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -112,7 +112,7 @@ server.get('/scenario_package', bodyParser.json(), function (req, res) {
} }
}); });
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
//parse request body into a where clause //parse request body into a where clause
@ -126,14 +126,14 @@ server.get('/scenario_package', bodyParser.json(), function (req, res) {
console.log(new Date().toISOString() + "-------------------------get scenario:------------------------------") console.log(new Date().toISOString() + "-------------------------get scenario:------------------------------")
console.log(req.body); console.log(req.body);
//parse the where clause into the main sql statement //parse the where clause into the main sql statement
sql = sql.replace(new RegExp("where_clause",'g'),w) sql = sql.replace(new RegExp("where_clause", 'g'), w)
//execute the sql and send the result //execute the sql and send the result
//console.log(sql); //console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
}; };
}) })
server.get('/list_changes', bodyParser.json(), function (req, res) { server.get('/list_changes', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -142,8 +142,8 @@ server.get('/list_changes', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/list_changes.sql'; var path = './route_sql/list_changes.sql';
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -151,20 +151,20 @@ server.get('/list_changes', bodyParser.json(), function (req, res) {
} }
}); });
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
console.log(new Date().toISOString() +"-------------------------list changes:------------------------------") console.log(new Date().toISOString() + "-------------------------list changes:------------------------------")
console.log(req.body); console.log(req.body);
//parse the where clause into the main sql statement //parse the where clause into the main sql statement
sql = sql.replace(new RegExp("replace_user",'g'),JSON.stringify(req.body)) sql = sql.replace(new RegExp("replace_user", 'g'), JSON.stringify(req.body.quota_rep_descr))
//execute the sql and send the result //execute the sql and send the result
//console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
}; };
}) })
server.post('/addmonth_v', bodyParser.json(), function (req, res) { server.post('/addmonth_v', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -173,8 +173,8 @@ server.post('/addmonth_v', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/addmonth_vd.sql'; var path = './route_sql/addmonth_vd.sql';
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -182,7 +182,7 @@ server.post('/addmonth_v', bodyParser.json(), function (req, res) {
} }
}); });
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
//buile where clause expression //buile where clause expression
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -191,22 +191,22 @@ server.post('/addmonth_v', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"-----------------------------add month volume:---------------------------------"); console.log(new Date().toISOString() + "-----------------------------add month volume:---------------------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("scenario = target_scenario",'g'),w); sql = sql.replace(new RegExp("scenario = target_scenario", 'g'), w);
sql = sql.replace(new RegExp("target_increment",'g'),req.body.qty); sql = sql.replace(new RegExp("target_increment", 'g'), req.body.qty);
sql = sql.replace(new RegExp("target_month",'g'),req.body.month); sql = sql.replace(new RegExp("target_month", 'g'), req.body.month);
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql) console.log(sql)
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
}) })
server.post('/addmonth_vp', bodyParser.json(), function (req, res) { server.post('/addmonth_vp', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -215,7 +215,7 @@ server.post('/addmonth_vp', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/addmonth_vupd.sql'; var path = './route_sql/addmonth_vupd.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -224,23 +224,23 @@ server.post('/addmonth_vp', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"------------------add month volume and price:-------------------"); console.log(new Date().toISOString() + "------------------add month volume and price:-------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("where_clause",'g'),w); sql = sql.replace(new RegExp("where_clause", 'g'), w);
sql = sql.replace(new RegExp("target_volume",'g'),req.body.qty); sql = sql.replace(new RegExp("target_volume", 'g'), req.body.qty);
sql = sql.replace(new RegExp("target_price",'g'),req.body.amount); sql = sql.replace(new RegExp("target_price", 'g'), req.body.amount);
sql = sql.replace(new RegExp("target_month",'g'),req.body.month); sql = sql.replace(new RegExp("target_month", 'g'), req.body.month);
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -249,7 +249,7 @@ server.post('/addmonth_vp', bodyParser.json(), function (req, res) {
}); });
}) })
server.post('/scale_v', bodyParser.json(), function (req, res) { server.post('/scale_v', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -258,7 +258,7 @@ server.post('/scale_v', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/scale_vd.sql'; var path = './route_sql/scale_vd.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -267,21 +267,21 @@ server.post('/scale_v', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"-----------------------scale volume:------------------------------"); console.log(new Date().toISOString() + "-----------------------scale volume:------------------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("where_clause",'g'),w); sql = sql.replace(new RegExp("where_clause", 'g'), w);
sql = sql.replace(new RegExp("incr_qty",'g'),req.body.qty); sql = sql.replace(new RegExp("incr_qty", 'g'), req.body.qty);
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -290,7 +290,7 @@ server.post('/scale_v', bodyParser.json(), function (req, res) {
}); });
}) })
server.post('/scale_p', bodyParser.json(), function (req, res) { server.post('/scale_p', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -299,7 +299,7 @@ server.post('/scale_p', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/scale_pd.sql'; var path = './route_sql/scale_pd.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -308,21 +308,21 @@ server.post('/scale_p', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"--------------------scale price:-------------------"); console.log(new Date().toISOString() + "--------------------scale price:-------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("where_clause",'g'),w); sql = sql.replace(new RegExp("where_clause", 'g'), w);
sql = sql.replace(new RegExp("target_increment",'g'),req.body.amount); sql = sql.replace(new RegExp("target_increment", 'g'), req.body.amount);
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -331,7 +331,7 @@ server.post('/scale_p', bodyParser.json(), function (req, res) {
}); });
}) })
server.post('/scale_vp', bodyParser.json(), function (req, res) { server.post('/scale_vp', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -340,7 +340,7 @@ server.post('/scale_vp', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/scale_vupd.sql'; var path = './route_sql/scale_vupd.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -349,22 +349,22 @@ server.post('/scale_vp', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"--------------------scale volume & price:-------------------"); console.log(new Date().toISOString() + "--------------------scale volume & price:-------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("where_clause",'g'),w); sql = sql.replace(new RegExp("where_clause", 'g'), w);
sql = sql.replace(new RegExp("target_vol",'g'),req.body.qty); sql = sql.replace(new RegExp("target_vol", 'g'), req.body.qty);
sql = sql.replace(new RegExp("target_prc",'g'),req.body.amount); sql = sql.replace(new RegExp("target_prc", 'g'), req.body.amount);
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -373,7 +373,7 @@ server.post('/scale_vp', bodyParser.json(), function (req, res) {
}); });
}) })
server.post('/new_part', bodyParser.json(), function (req, res) { server.post('/new_part', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -382,7 +382,7 @@ server.post('/new_part', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/new_part.sql'; var path = './route_sql/new_part.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -391,23 +391,23 @@ server.post('/new_part', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"--------------------new part:-------------------"); console.log(new Date().toISOString() + "--------------------new part:-------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("where_clause",'g'),w); sql = sql.replace(new RegExp("where_clause", 'g'), w);
sql = sql.replace(new RegExp("target_vol",'g'),req.body.qty); sql = sql.replace(new RegExp("target_vol", 'g'), req.body.qty);
sql = sql.replace(new RegExp("target_prc",'g'),req.body.amount); sql = sql.replace(new RegExp("target_prc", 'g'), req.body.amount);
sql = sql.replace(new RegExp("replace_request",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_request", 'g'), JSON.stringify(req.body));
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -416,7 +416,7 @@ server.post('/new_part', bodyParser.json(), function (req, res) {
}); });
}) })
server.post('/new_basket', bodyParser.json(), function (req, res) { server.post('/new_basket', bodyParser.json(), function(req, res) {
var sql = ""; var sql = "";
var w = ""; var w = "";
@ -425,7 +425,7 @@ server.post('/new_basket', bodyParser.json(), function (req, res) {
var args = []; var args = [];
var path = './route_sql/new_basket.sql'; var path = './route_sql/new_basket.sql';
var callback = function(arg){ var callback = function(arg) {
sql = arg; sql = arg;
({ c, w, d } = build_where(req, c, w, d, args)); ({ c, w, d } = build_where(req, c, w, d, args));
@ -434,23 +434,23 @@ server.post('/new_basket', bodyParser.json(), function (req, res) {
res.send("no body was sent"); res.send("no body was sent");
return; return;
} }
console.log(new Date().toISOString() +"--------------------new basket:-------------------"); console.log(new Date().toISOString() + "--------------------new basket:-------------------");
req.body.stamp = new Date().toISOString() req.body.stamp = new Date().toISOString()
console.log(req.body); console.log(req.body);
//console.log(args); //console.log(args);
sql = sql.replace(new RegExp("where_clause",'g'),w); sql = sql.replace(new RegExp("where_clause", 'g'), w);
sql = sql.replace(new RegExp("target_vol",'g'),req.body.qty); sql = sql.replace(new RegExp("target_vol", 'g'), req.body.qty);
sql = sql.replace(new RegExp("target_prc",'g'),req.body.amount); sql = sql.replace(new RegExp("target_prc", 'g'), req.body.amount);
sql = sql.replace(new RegExp("replace_request",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_request", 'g'), JSON.stringify(req.body));
sql = sql.replace(new RegExp("replace_version",'g'),req.body.scenario.version); sql = sql.replace(new RegExp("replace_version", 'g'), req.body.scenario.version);
sql = sql.replace(new RegExp("replace_source",'g'),req.body.source); sql = sql.replace(new RegExp("replace_source", 'g'), req.body.source);
sql = sql.replace(new RegExp("replace_iterdef",'g'),JSON.stringify(req.body)); sql = sql.replace(new RegExp("replace_iterdef", 'g'), JSON.stringify(req.body));
console.log(sql); console.log(sql);
Postgres.FirstRow(sql,[],res) Postgres.FirstRow(sql, [], res)
} }
fs.readFile(path, 'utf8', function(err, data){ fs.readFile(path, 'utf8', function(err, data) {
if (!err){ if (!err) {
callback(data); callback(data);
} else { } else {
console.log("fatal error pulling sql file") console.log("fatal error pulling sql file")
@ -480,13 +480,11 @@ function build_where(req, c, w, d, args) {
d = d + 1; d = d + 1;
} }
w = w + ")"; w = w + ")";
} } else {
else {
w = w + i + " = '" + req.body.scenario[i] + "'"; w = w + i + " = '" + req.body.scenario[i] + "'";
} }
args.push(req.body.scenario[i]); args.push(req.body.scenario[i]);
c = c + 1; c = c + 1;
} };
;
return { c, w, d }; return { c, w, d };
} }

View File

@ -50,13 +50,13 @@ SELECT
,plnt ,plnt
,promo ,promo
,terms ,terms
,bill_cust||' - '||bc.bvname bill_custd ,bill_cust||' - '||bc.bvname bill_cust_descr
,ship_cust||' - '||sc.bvname ship_custd ,ship_cust||' - '||sc.bvname ship_cust_descr
,dsm ,dsm
,coalesce(repc.repp,dsm) dsmd ,coalesce(repc.repp,dsm) quota_rep_descr
,repc.director ,repc.director
,account bill_dba ,account billto_group
,shipgrp ship_dba ,shipgrp shipto_group
,chan ,chan
,chansub ,chansub
,CASE seg.segm ,CASE seg.segm
@ -69,40 +69,40 @@ SELECT
ELSE o.chan ELSE o.chan
END chan_retail END chan_retail
,part ,part
,part||coalesce(' - '||i.descr,'') partd ,part||coalesce(' - '||i.descr,'') part_descr
,stlcd partgroup ,stlcd part_group
,brnd ,brnd branding
,o.majg||' - '||i.majgd majgd ,o.majg||' - '||i.majgd majg_descr
,o.ming||' - '||i.mingd mingd ,o.ming||' - '||i.mingd ming_descr
,o.majs||' - '||i.majsd majsd ,o.majs||' - '||i.majsd majs_descr
,o.mins||' - '||i.minsd minsd ,o.mins||' - '||i.minsd mins_descr
,seg.segm ,seg.segm
,fs_line ,fs_line
,r_currency ,r_currency
,r_rate ,r_rate
,c_currency ,c_currency
,c_rate ,c_rate
,fb_qty ,fb_qty units
,fb_val_loc ,fb_val_loc value_loc
,fb_val_loc * r_rate value_usd ,fb_val_loc * r_rate value_usd
,fb_cst_loc ,fb_cst_loc cost_loc
,fb_cst_loc * c_rate cost_usd ,fb_cst_loc * c_rate cost_usd
,calc_status ,calc_status
,flag ,flag
,o.odate ,o.odate order_date
,to_char(CASE WHEN extract(month FROM o.odate) > 6 THEN -5 ELSE 7 END + extract(month FROM o.odate),'FM00')||' - '||to_char(o.odate,'TMMon') omonth ,to_char(CASE WHEN extract(month FROM o.odate) > 6 THEN -5 ELSE 7 END + extract(month FROM o.odate),'FM00')||' - '||to_char(o.odate,'TMMon') order_month
,oseas ,oseas order_season
,rdate ,rdate request_date
,to_char(CASE WHEN extract(month FROM o.rdate) > 6 THEN -5 ELSE 7 END + extract(month FROM o.rdate),'FM00')||' - '||to_char(o.rdate,'TMMon') rmonth ,to_char(CASE WHEN extract(month FROM o.rdate) > 6 THEN -5 ELSE 7 END + extract(month FROM o.rdate),'FM00')||' - '||to_char(o.rdate,'TMMon') request_month
,rseas ,rseas request_season
,sdate ,sdate ship_date
,to_char(CASE WHEN extract(month FROM o.sdate) > 6 THEN -5 ELSE 7 END + extract(month FROM o.sdate),'FM00')||' - '||to_char(o.sdate,'TMMon') smonth ,to_char(CASE WHEN extract(month FROM o.sdate) > 6 THEN -5 ELSE 7 END + extract(month FROM o.sdate),'FM00')||' - '||to_char(o.sdate,'TMMon') ship_month
,sseas ,sseas ship_season
,version ,version
,iter ,iter
,null::int logid ,null::int logid
,null::text "comment" ,null::text "comment"
,null::text iterdet ,null::text module
FROM FROM
rlarp.osmf_dev o rlarp.osmf_dev o
LEFT OUTER JOIN lgdat.cust bc ON LEFT OUTER JOIN lgdat.cust bc ON
@ -129,3 +129,13 @@ FROM
i.item = o.part i.item = o.part
--LIMIT 100 --LIMIT 100
) WITH DATA; ) WITH DATA;
CREATE INDEX osm_qr ON rlarp.osm_pool(quota_rep_descr);
DROP TABLE IF EXISTS rlarp.osm_log;
CREATE TABLE IF NOT EXISTS rlarp.osm_log(id INT PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY, doc jsonb);
GRANT ALL ON TABLE rlarp.osm_log TO api;
GRANT ALL ON TABLE rlarp.osm_pool TO api;

View File

@ -552,7 +552,7 @@ SELECT
,o.sdate + interval '1 year' --incremented ,o.sdate + interval '1 year' --incremented
,o.sseas + 1 --incremented ,o.sseas + 1 --incremented
,'b21' "version" ,'b21' "version"
,'baseline' iter ,'copy' iter
FROM FROM
baseline o baseline o
LEFT OUTER JOIN gld ON LEFT OUTER JOIN gld ON

View File

@ -6,20 +6,20 @@ SELECT
,ship_cust_descr ,ship_cust_descr
,shipto_group ,shipto_group
,quota_rep_descr ,quota_rep_descr
,director_descr ,director
,segm ,segm
,mod_chan ,chan
,mod_chansub ,chansub
---------product info------------------ ---------product info------------------
,majg_descr ,majg_descr
,ming_descr ,ming_descr
,majs_descr ,majs_descr
,mins_descr ,mins_descr
,brand --,brand
,part_family --,part_family
,part_group ,part_group
,branding ,branding
,color --,color
,part_descr ,part_descr
---------dates------------------------- ---------dates-------------------------
,order_season ,order_season
@ -38,7 +38,7 @@ SELECT
,sum(cost_usd) cost_usd ,sum(cost_usd) cost_usd
,sum(units) units ,sum(units) units
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
WHERE WHERE
quota_rep_descr = 'rep_replace' quota_rep_descr = 'rep_replace'
GROUP BY GROUP BY
@ -48,20 +48,20 @@ GROUP BY
,ship_cust_descr ,ship_cust_descr
,shipto_group ,shipto_group
,quota_rep_descr ,quota_rep_descr
,director_descr ,director
,segm ,segm
,mod_chan ,chan
,mod_chansub ,chansub
---------product info------------------ ---------product info------------------
,majg_descr ,majg_descr
,ming_descr ,ming_descr
,majs_descr ,majs_descr
,mins_descr ,mins_descr
,brand --,brand
,part_family --,part_family
,part_group ,part_group
,branding ,branding
,color --,color
,part_descr ,part_descr
---------dates------------------------- ---------dates-------------------------
,order_season ,order_season

View File

@ -1,21 +1,37 @@
WITH WITH
list AS ( list AS materialized (
SELECT SELECT
iterdef->>'user' "user", l.doc->>'user' "user",
iterdef->>'stamp' "stamp", jsonb_path_query_first(l.doc,'$.scenario.quota_rep_descr')->>0 quota_rep_descr,
iterdef->>'mesasage' "comment", to_char((l.doc->>'stamp')::timestamptz,'YYYY-MM-DD HH:MI:SS') "stamp",
round(SUM(fb_val_loc * r_rate)::numeric,2) sales, l.doc->>'message' "comment",
jsonb_pretty(iterdef) def jsonb_pretty(l.doc) def,
l.id
FROM FROM
rlarp.osm_fcpool rlarp.osm_log l
WHERE WHERE
iterdef IS NOT NULL l.doc @? '$.scenario.quota_rep_descr ? (@ == replace_user)'
AND iterdef @> $$replace_user$$::jsonb )
GROUP BY ,agg as (
iterdef->>'user', SELECT
iterdef->>'stamp', list.user
iterdef->>'message', ,list.quota_rep_descr
iterdef ,list.stamp
,list.comment
,list.def
,list.id
,to_char(round(sum(value_usd),2),'$999,999,999D00') sales
from
LIST
inner join rlarp.osm_pool on
id = logid
group BY
list.user
,list.quota_rep_descr
,list.stamp
,list.comment
,list.def
,list.id
) )
SELECT SELECT
jsonb_agg(row_to_json(list)::jsonb) x from list jsonb_agg(row_to_json(agg)::jsonb ORDER BY agg.stamp desc) x from agg

View File

@ -13,6 +13,7 @@ target AS (select $$replace_request$$::json def)
,to_char(N1FSYP,'FM0000') FSPR ,to_char(N1FSYP,'FM0000') FSPR
,N1SD01 SDAT ,N1SD01 SDAT
,N1ED01 EDAT ,N1ED01 EDAT
,daterange(n1sd01, n1ed01) drange
,to_char(N1ED01,'yymm') CAPR ,to_char(N1ED01,'yymm') CAPR
,N1ED01 - N1SD01 +1 NDAYS ,N1ED01 - N1SD01 +1 NDAYS
,CASE WHEN EXTRACT(MONTH FROM N1ED01) >= 6 THEN EXTRACT(YEAR FROM N1ED01) + 1 ELSE EXTRACT(YEAR FROM N1ED01) END SSYR ,CASE WHEN EXTRACT(MONTH FROM N1ED01) >= 6 THEN EXTRACT(YEAR FROM N1ED01) + 1 ELSE EXTRACT(YEAR FROM N1ED01) END SSYR
@ -30,18 +31,18 @@ target AS (select $$replace_request$$::json def)
SELECT * FROM SELECT * FROM
( (
VALUES VALUES
('Jun',1,6,-1) ('01 - Jun',1,6,-1)
,('Jul',2,7,-1) ,('02 - Jul',2,7,-1)
,('Aug',3,8,-1) ,('03 - Aug',3,8,-1)
,('Sep',4,9,-1) ,('04 - Sep',4,9,-1)
,('Oct',5,10,-1) ,('05 - Oct',5,10,-1)
,('Nov',6,11,-1) ,('06 - Nov',6,11,-1)
,('Dec',7,12,-1) ,('07 - Dec',7,12,-1)
,('Jan',8,1,0) ,('08 - Jan',8,1,0)
,('Feb',9,2,0) ,('09 - Feb',9,2,0)
,('Mar',10,3,0) ,('10 - Mar',10,3,0)
,('Apr',11,4,0) ,('11 - Apr',11,4,0)
,('May',12,5,0) ,('12 - May',12,5,0)
) x(m,s,cal,yr) ) x(m,s,cal,yr)
) )
,SEG AS ( ,SEG AS (
@ -67,30 +68,6 @@ target AS (select $$replace_request$$::json def)
('9TO','Other') ('9TO','Other')
) X(GLEC, SEGM) ) X(GLEC, SEGM)
) )
,MG AS (
SELECT
X.F1, X.MING, X.GRP
FROM
(
VALUES
('L','000','Branded'),
('L','B10','Branded'),
('L','B11','Branded'),
('L','B52','Branded'),
('L','C10','Branded'),
('L','D12','Branded'),
('L','M11','Branded'),
('L','P12','Branded'),
('L','P13','Branded'),
('L','S10','Branded'),
('L','Y10','Branded'),
('L','Y11','Branded'),
('L','Y12','Branded'),
('P','B10','Branded'),
('P','B11','Branded'),
('P','B52','Branded')
) AS X (F1, MING, GRP)
)
,REPC AS ( ,REPC AS (
SELECT SELECT
LTRIM(RTRIM(C.A9)) RCODE LTRIM(RTRIM(C.A9)) RCODE
@ -103,46 +80,6 @@ target AS (select $$replace_request$$::json def)
WHERE WHERE
C.A2 = 'MM' C.A2 = 'MM'
) )
--MOLD DESCRIPTIONS
,MD AS (
SELECT
U.MOLD
,MAX(U.DESCR) DESCR
FROM
(
SELECT
SUBSTR(M.AVPART,1,8) MOLD
,MAX(M.AVDES1) DESCR
FROM
LGDAT.STKMM M
WHERE
LENGTH(M.AVPART) > 8
AND SUBSTR(M.AVGLED,1,1) <= '2'
GROUP BY
SUBSTR(M.AVPART,1,8)
UNION ALL
SELECT
SUBSTR(P.AWPART,1,8) MOLD
,MAX(P.AWDES1) DESCR
FROM
LGDAT.STKMP P
WHERE
LENGTH(P.AWPART) > 8
AND SUBSTR(P.AWGLED,1,1) <= '2'
GROUP BY
SUBSTR(P.AWPART,1,8)
) U
GROUP BY
U.MOLD
)
----------------------------------------------------sales major codes----------------------------------------------------------------------------------------------------------------------------------
,SJ AS (
SELECT * FROM LGDAT.MMSL WHERE COALESCE(BSMNCD,'') = ''
)
----------------------------------------------------sales minor codes----------------------------------------------------------------------------------------------------------------------------------
,SI AS (
SELECT * FROM LGDAT.MMSL WHERE COALESCE(BSMNCD,'') <> ''
)
,copr AS ( ,copr AS (
SELECT SELECT
LTRIM(RTRIM(A9)) AS COMP, LTRIM(RTRIM(A9)) AS COMP,
@ -169,12 +106,12 @@ target AS (select $$replace_request$$::json def)
,terms ,terms
,order_month ,order_month
,mseq.s seq ,mseq.s seq
,orderdate ,order_date
,requestdate ,request_date
,shipdate ,ship_date
,sum(value_usd) value_usd ,sum(value_usd) value_usd
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
LEFT OUTER JOIN mseq ON LEFT OUTER JOIN mseq ON
mseq.m = order_month mseq.m = order_month
WHERE WHERE
@ -183,50 +120,52 @@ target AS (select $$replace_request$$::json def)
--probably dont want to include adjustments that have blown away volume and good sources of dating info --probably dont want to include adjustments that have blown away volume and good sources of dating info
-----------------additional params------------------- -----------------additional params-------------------
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate AND order_date <= ship_date
GROUP BY GROUP BY
promo promo
,terms ,terms
,order_month ,order_month
,mseq.s ,mseq.s
,orderdate ,order_date
,requestdate ,request_date
,shipdate ,ship_date
HAVING HAVING
sum(value_usd) <> 0 sum(value_usd) <> 0
) )
--select * from alldates --select * from alldates
,dom AS ( ,dom AS (
SELECT SELECT
extract(day FROM orderdate) DOM extract(day FROM order_date) DOM
,sum(value_usd) value_usd ,sum(value_usd) value_usd
FROM FROM
alldates alldates
GROUP BY GROUP BY
extract(day FROM orderdate) extract(day FROM order_date)
) )
--select * from dom
---------------------may want ot look at a top-5 mix solution in the future facilitated by sum() over (order by sales desc)--------------- ---------------------may want ot look at a top-5 mix solution in the future facilitated by sum() over (order by sales desc)---------------
,mmix AS ( ,mmix AS (
SELECT SELECT
to_char(orderdate,'Mon') _month to_char(order_date,'Mon') _month
,seq ,seq
,promo ,promo
,sum(extract(day from orderdate)*value_usd) dom_wa ,sum(extract(day from order_date)*value_usd) dom_wa
--,requestdate-orderdate rlag --,request_date-order_date rlag
,sum((requestdate-orderdate)*(value_usd)) rlag_wa ,sum((request_date-order_date)*(value_usd)) rlag_wa
--,shipdate - requestdate slag --,ship_date - request_date slag
,sum((shipdate - requestdate)*(value_usd)) slag_wa ,sum((ship_date - request_date)*(value_usd)) slag_wa
,sum(value_usd) value_usd ,sum(value_usd) value_usd
FROM FROM
alldates alldates
GROUP BY GROUP BY
to_char(orderdate,'Mon') to_char(order_date,'Mon')
,seq ,seq
,promo ,promo
--,extract(day from orderdate) --,extract(day from order_date)
--,requestdate-orderdate --,request_date-order_date
--,shipdate - requestdate --,ship_date - request_date
) )
--select * from mmix
,targm AS ( ,targm AS (
SELECT SELECT
je.key as month je.key as month
@ -242,6 +181,7 @@ target AS (select $$replace_request$$::json def)
LEFT OUTER JOIN mseq ON LEFT OUTER JOIN mseq ON
mseq.m = je.key mseq.m = je.key
) )
--select * from targm
,mmixp AS ( ,mmixp AS (
SELECT SELECT
_month _month
@ -255,6 +195,7 @@ target AS (select $$replace_request$$::json def)
FROM FROM
mmix mmix
) )
--select * from mmixp
--month cross join mix --month cross join mix
,mxm AS ( ,mxm AS (
SELECT SELECT
@ -286,114 +227,24 @@ FROM
--this basemix is probably join going to be part-bill-ship with all master data joined later since it is not known if any original is salvaged --this basemix is probably join going to be part-bill-ship with all master data joined later since it is not known if any original is salvaged
,basemix AS ( ,basemix AS (
SELECT SELECT
null::text plnt ---master data sd.fspr
,0::numeric(11,0) "ddord#" ,mxm.promo
,0::numeric(11,0) "dditm#"
,0::numeric(11,0) "fgbol#"
,0::numeric(11,0) "fgent#"
,0::numeric(9,0) "diinv#"
,0::numeric(3,0) "dilin#"
,mxm.promo --history
,null::text return_reas
,null::text terms
,''::text custpo
,'I' dhincr
,null::numeric diext
,null::numeric ditdis
,null::date dcodat
,null::date ddqdat
,null::date dcmdat
,null::date dhidat
,sd.fspr
,null::text remit_to
,null::text bill_class
,(regexp_match(jr.bill_cust_descr,'(.*?)(?= - |$)'))[1] bill_cust
,null:: text bill_rep
,null::text bill_terr
,null::text ship_class
,(regexp_match(jr.ship_cust_descr,'(.*?)(?= - |$)'))[1] ship_cust
,null::text ship_rep
,null::text ship_terr
,null::text quota_rep
,null::text account
,null::text shipgrp
,null::text geo
,null::text chan
,null::text orig_ctry
,null::text orig_prov
,null::text orig_post
,null::text dest_ctry
,null::text dest_prov
,null::text dest_post
,(regexp_match(jr.part_descr,'(.*?)(?= - |$)'))[1] part
,null::text ord_gldc
,null::text majg
,null::text ming
,null::text majs
,null::text mins
,null::text gldc
,null::text glec
,null::text harm
,null::text clss
,null::text brand
,null::text assc
,'41010'::text fs_line
,null::text r_currency
,null::numeric r_rate
,null::text c_currency
,null::numeric c_rate
,0::numeric(15,5) ddqtoi
,0::numeric(15,5) ddqtsi
,0::numeric(15,5) fgqshp
,0::numeric(15,5) diqtsh
,mxm.qty*mxm.momix*jr.mix fb_qty --history value
,0::numeric fb_cst_loc --history part mix
,0::numeric fb_cst_loc_cur
,0::numeric fb_cst_loc_fut
,mxm.amount*mxm.momix*jr.mix fb_val_loc --history value
,0::numeric fb_val_loc_pl
,''::text calc_status
,''::text flag
,make_date(mxm.yr + 2020,mxm.cal,mxm.odom) orderdate
,make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag requestdate
,make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag + slag shipdate
,make_date(mxm.yr + 2020,mxm.cal,mxm.odom) adj_orderdate
,make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag adj_requestdate
,make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag + slag adj_shipdate
,'replace_version' "version"
,'replace_source'||' volume' iter
-----------------------ui columns--------------------------------
,'replace_iterdet' iterdet
,$$replace_iterdef$$::json iterdef
,od.ssyr order_season
,to_char(make_date(mxm.yr + 2020,mxm.cal,mxm.odom),'Mon') order_month
,sd.ssyr ship_season
,to_char(make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag + slag,'Mon') ship_month
,rd.ssyr request_season
,to_char(make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag,'Mon') request_month
,jr.part_descr part_descr
,null::text part_family
,null::text part_group
,null::text branding
,null::text color
,null::text segm
,jr.bill_cust_descr ,jr.bill_cust_descr
,null::text billto_group
,jr.ship_cust_descr ,jr.ship_cust_descr
,null::text shipto_group ,(regexp_match(jr.part_descr,'(.*?)(?= - |$)'))[1] part
,null::text majg_descr ,jr.part_descr
,null::text ming_descr ,substring(jr.part_descr,1,8) part_group
,null::text majs_descr ,mxm.qty*mxm.momix*jr.mix units
,null::text mins_descr ,mxm.amount*mxm.momix*jr.mix value_loc
,null::text mod_chan ,make_date(mxm.yr + 2021,mxm.cal,mxm.odom) order_date
,null::text mod_chansub ,to_char(make_date(mxm.yr + 2021,mxm.cal,mxm.odom),'Mon') order_month
,null::text quota_rep_descr ,od.ssyr order_season
,null::text director_descr ,make_date(mxm.yr + 2021,mxm.cal,mxm.odom) + rlag request_date
,null::numeric value_loc ,to_char(make_date(mxm.yr + 2021,mxm.cal,mxm.odom) + rlag,'Mon') request_month
,null::numeric value_usd ,rd.ssyr request_season
,null::numeric cost_loc ,make_date(mxm.yr + 2021,mxm.cal,mxm.odom) + rlag + slag ship_date
,null::numeric cost_usd ,to_char(make_date(mxm.yr + 2021,mxm.cal,mxm.odom) + rlag + slag,'Mon') ship_month
,null::numeric units ,sd.ssyr ship_season
,jr.mix ,jr.mix
FROM FROM
target target
@ -401,387 +252,245 @@ SELECT
JOIN LATERAL json_to_record(ae.e) as jr(part_descr text, bill_cust_descr text, ship_cust_descr text, mix numeric) ON true JOIN LATERAL json_to_record(ae.e) as jr(part_descr text, bill_cust_descr text, ship_cust_descr text, mix numeric) ON true
CROSS JOIN mxm CROSS JOIN mxm
LEFT OUTER JOIN gld od ON LEFT OUTER JOIN gld od ON
make_date(mxm.yr + 2020,mxm.cal,mxm.odom) BETWEEN od.sdat AND od.edat od.drange @> make_date(mxm.yr + 2021,mxm.cal,mxm.odom)
LEFT OUTER JOIN gld rd ON LEFT OUTER JOIN gld rd ON
make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag BETWEEN rd.sdat AND rd.edat rd.drange @> (make_date(mxm.yr + 2021,mxm.cal,mxm.odom) + rlag)
LEFT OUTER JOIN gld sd ON LEFT OUTER JOIN gld sd ON
make_date(mxm.yr + 2020,mxm.cal,mxm.odom) + rlag + slag BETWEEN sd.sdat AND sd.edat sd.drange @> (make_date(mxm.yr + 2021,mxm.cal,mxm.odom) + rlag + slag)
) )
--SELECT * FROM basemix --SELECT * FROM basemix
,log AS (
INSERT INTO rlarp.osm_log(doc) SELECT $$replace_iterdef$$::jsonb doc RETURNING *
)
,final AS ( ,final AS (
SELECT SELECT
COALESCE(m.avdplt,p.awdplt) plnt --master data b.fspr
,b."ddord#" ,i.dplt plnt
,b."dditm#" ,b.promo
,b."fgbol#" ,bc.bvterm terms
,b."fgent#" ,b.bill_cust_descr
,b."diinv#" ,b.ship_cust_descr
,b."dilin#" ,(SELECT rcode FROM repc WHERE repp = log.doc->'scenario'->>'quota_rep_descr') dsm
,b.promo --history ,log.doc->'scenario'->>'quota_rep_descr' quota_rep_descr
,b.return_reas ,(SELECT director FROM repc WHERE repp = log.doc->'scenario'->>'quota_rep_descr') director
,bc.bvterm terms --history cust mix ,CASE bc.BVADR6 WHEN '' THEN bc.BVNAME ELSE bc.BVADR6 END billto_group
,b.custpo ,CASE sc.BVADR6 WHEN '' THEN sc.BVNAME ELSE bc.BVADR6 END shipto_group
,b.dhincr ,CASE SUBSTRING(bc.bvclas,2,3)
,b.diext --if the bill to class is ditsributor, then it's either warehouse or drop
,b.ditdis WHEN 'DIS' THEN
,b.dcodat --if the ship-to is a different name than the bill-to then it's drop, otherwise it's warehouse
,b.ddqdat CASE SUBSTRING(sc.bvclas,2,3)
,b.dcmdat WHEN 'DIS' THEN 'WHS'
,b.dhidat ELSE 'DRP'
,b.fspr
,bc.bvcomp remit_to --master data
,bc.bvclas bill_class --master data
,b.bill_cust --history cust mix
,bc.bvsalm bill_rep --master data
,bc.bvterr bill_terr --master data
,sc.bvclas ship_class --master data
,b.ship_cust --history cust mix
,sc.bvsalm ship_rep --master data
,sc.bvterr ship_terr --master data
--quota rep--------------------------------------------
,RTRIM(
COALESCE(
--retail items go to currep, or if null go to 90005
CASE WHEN COALESCE(avgled,awgled) IN ('1RE','1CU') THEN
CASE WHEN bc.bvctry = 'CAN' THEN
--Rachel Bowman
'50300'
ELSE
--retail chain got to Mark Wilkinson
CASE COALESCE(cg.cgrp,bc.bvname)
WHEN 'THE HOME DEPOT' THEN '90005'
WHEN 'DO IT BEST' THEN '90005'
WHEN 'ACE HARDWARE' THEN '90005'
WHEN 'ALDI' THEN '90005'
WHEN 'AMAZON.COM' THEN '90005'
WHEN 'GARDEN RIDGE CORP' THEN '90005'
--all other retail goes to Doran Marable
ELSE '50200'
END
END END
ELSE --CASE WHEN RTRIM(SUBSTRING(LTRIM(SC.BVADR7)||SC.BVNAME,1,30)) = RTRIM(SUBSTRING(LTRIM(BC.BVADR7)||BC.BVNAME,1,30)) THEN 'DIS' ELSE 'DRP' END
CASE WHEN COALESCE(avming,awming) = 'B52' THEN --everything else does not involve a distributor and is considered direct
'PW' ELSE 'DIR'
--gdir, ndir go to bill-to rep END chan
ELSE ,CASE SUBSTRING(bc.bvclas,2,3)
CASE WHEN bc.bvclas IN ('GDIR','NDIR') THEN WHEN 'DIS' THEN
bc.bvsalm --if the ship-to is a different name than the bill-to then it's drop, otherwise it's warehouse
ELSE CASE SUBSTRING(sc.bvclas,2,3)
sc.bvsalm WHEN 'DIS' THEN 'WHS'
END ELSE CASE SUBSTRING(sc.bvclas,1,1) WHEN 'R' THEN 'RDP' ELSE 'DRP' END
END
END END
,'' WHEN 'MAS' THEN 'RMN'
) WHEN 'NAT' THEN 'RMN'
) quota_rep ELSE CASE SUBSTRING(sc.bvclas,1,1) WHEN 'R' THEN 'RDI' ELSE 'DIR' END
,coalesce(cg.cgrp,bc.bvname) account END chansub
,coalesce(sg.cgrp,sc.bvname) shipgrp ,null::text chan_retail
,coalesce(t.geo,'UNDEFINED') geo ,b.part
,coalesce(c.chan,'UNDEFINED') chan ,b.part_descr
,ad.qzcryc orig_ctry ,b.part_group
,ad.qzprov orig_prov ,i.branding
,ad.qzpost orig_post ,i.majg||' - '||i.majgd majg_descr
,sc.bvctry dest_ctry ,i.ming||' - '||i.mingd ming_descr
,sc.bvprcd dest_prov ,i.majs||' - '||i.majsd majs_descr
,sc.bvpost dest_post ,i.mins||' - '||i.minsd mins_descr
,b.part --history part mix ,seg.segm
,COALESCE(m.avglcd, p.awgldc) ord_gldc --master data ,'41010' fs_line --master data
,COALESCE(m.avmajg,p.awmajg) majg --master data
,COALESCE(m.avming,p.awming) ming --master data
,COALESCE(m.avmajs,p.awmajs) majs --master data
,COALESCE(m.avmins,p.awmins) mins --master data
,COALESCE(m.avglcd,p.awgldc) gldc --master data
,COALESCE(m.avgled,p.awgled) glec --master data
,COALESCE(m.avharm,p.awharm) harm --master data
,COALESCE(m.avclss,p.awclss) clss --master data
,SUBSTR(COALESCE(m."avcpt#",p."awvpt#"),1,1) brand --master data
,COALESCE(m.avassc,p.awassc) assc --master data
,b.fs_line --master data
,bc.bvcurr r_currency --history cust mix ,bc.bvcurr r_currency --history cust mix
,rx.rate r_rate --master data ,rx.rate r_rate --master data
,copr.curr c_currency --master data ,copr.curr c_currency --master data
,cx.rate c_rate --master data ,cx.rate c_rate --master data
,b.ddqtoi ,b.units
,b.ddqtsi ,b.value_loc
,b.fgqshp ,b.value_loc * rx.rate value_usd
,b.diqtsh ,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.units cost_loc
,b.fb_qty ,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.units*cx.rate cost_loc
,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.fb_qty fb_cst_loc ,'CLOSED' calc_status
,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.fb_qty fb_cst_loc_cur ,'SHIPMENT' flag
,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.fb_qty fb_cst_loc_fut ,b.order_date
,b.fb_val_loc
,b.fb_val_loc_pl
,b.calc_status
,b.flag
,b.orderdate
,b.requestdate
,b.shipdate
,b.adj_orderdate
,b.adj_requestdate
,b.adj_shipdate
,b."version"
,b.iter
-----------------------ui columns--------------------------------
,b.iterdet
,b.iterdef
,b.order_season
,b.order_month ,b.order_month
,b.ship_season ,b.order_season
,b.ship_month ,b.request_date
,b.request_season
,b.request_month ,b.request_month
,b.part_descr ,b.request_season
,SUBSTR(b.part,1,3)||coalesce(' - '||F.DESCR,'') part_family ,b.ship_date
,SUBSTRING(b.part,1,8)||coalesce(' - '||MD.DESCR,'') part_group ,b.ship_month
,COALESCE(MG.GRP,'Unbranded') branding ,b.ship_season
,CASE WHEN substring(COALESCE(m.avgled, p.awgled),1,1) <= '2' THEN SUBSTRING(b.part,9,3) ELSE '' END color ,'replace_version' "version"
,COALESCE(SEG.SEGM,'Other') segm ,'replace_source'||' volume' iter
,b.bill_cust_descr ,log.id
,coalesce(cg.cgrp,bc.bvname) billto_group ,log.doc->>'comment' "comment"
,b.ship_cust_descr ,log.doc->>'type' module
,coalesce(sg.cgrp,sc.bvname) shipto_group
,COALESCE(m.avmajg,p.awmajg)||COALESCE(' - '||BQDES,'') majg_descr
,COALESCE(m.avming,p.awming)||COALESCE(' - '||BRDES,'') ming_descr
,COALESCE(m.avmajs,p.awmajs)||COALESCE(' - '||SJ.BSDES1,'') majs_descr
,COALESCE(m.avmins,p.awmins)||COALESCE(' - '||SI.BSDES1,'') mins_descr
,CASE COALESCE(SEG.SEGM,'Other')
WHEN 'Retail' THEN c.RETAIL
ELSE coalesce(c.chan,'UNDEFINED')
END mod_chan
,CASE COALESCE(SEG.SEGM,'Other')
WHEN 'Retail' THEN c.RETAILSUB
ELSE ''
END mod_chansub
,repc.repp quota_rep_descr
,repc.director director_descr
,b.fb_val_loc value_loc
,b.fb_val_loc * rx.rate value_usd
,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.fb_qty cost_loc
,COALESCE(im.cgstcs,ip.chstcs, ir.y0stcs)*b.fb_qty*cx.rate cost_usd
,b.fb_qty units
FROM FROM
basemix b basemix b
LEFT OUTER JOIN LGDAT.STKMM M ON CROSS JOIN log
M.AVPART = b.PART LEFT OUTER JOIN rlarp.itemmv i ON
LEFT OUTER JOIN LGDAT.STKMP P ON i.item = b.part
P.AWPART = b.PART
LEFT OUTER JOIN lgdat.stka a ON
v6part = b.part
AND v6plnt = COALESCE(m.avdplt,p.awdplt)
LEFT OUTER JOIN SEG ON LEFT OUTER JOIN SEG ON
SEG.GLEC = COALESCE(m.avgled,p.awgled) SEG.GLEC = i.glec
--AND SEG.SEGM <> 'Other' --AND SEG.SEGM <> 'Other'
LEFT OUTER JOIN MG ON
MG.F1 = SUBSTR(b.PART,16,1)
AND MG.MING = COALESCE(m.avming,p.awming)
LEFT OUTER JOIN RLARP.FAMILY F ON
F.F3 = SUBSTR(b.PART,1,3)
LEFT OUTER JOIN MD ON
MD.MOLD = SUBSTR(b.PART,1,8)
LEFT OUTER JOIN LGDAT.CUST BC ON LEFT OUTER JOIN LGDAT.CUST BC ON
BC.BVCUST = b.BILL_CUST BC.BVCUST = rtrim(substring(b.bill_cust_descr,1,8))
LEFT OUTER JOIN LGDAT.CUST SC ON LEFT OUTER JOIN LGDAT.CUST SC ON
SC.BVCUST = b.SHIP_CUST SC.BVCUST = rtrim(substring(b.ship_cust_descr,1,8))
LEFT OUTER JOIN RLARP.FFCHNL c ON
c.BILL = bc.bvclas
AND c.SHIP = sc.bvclas
LEFT OUTER JOIN rlarp.ffterr t ON
t.prov = sc.bvprcd AND
t.ctry = sc.bvctry
LEFT OUTER JOIN RLARP.FFCUST CG ON
CG.CUSTN = BC.BVCUST
LEFT OUTER JOIN RLARP.FFCUST SG ON
SG.CUSTN = SC.BVCUST
LEFT OUTER JOIN REPC ON LEFT OUTER JOIN REPC ON
REPC.RCODE = RTRIM( REPC.RCODE = RTRIM(
COALESCE( --retail items go to currep, or if null go to 90005
--retail items go to currep, or if null go to 90005 CASE WHEN i.glec IN ('1RE','1CU') THEN
CASE WHEN COALESCE(avgled,awgled) IN ('1RE','1CU') THEN CASE WHEN bc.bvctry = 'CAN' THEN
CASE WHEN bc.bvctry = 'CAN' THEN --Rachel Bowman
--Rachel Bowman '50300'
'50300' ELSE
ELSE --select customers go to select reps
--retail chain got to Mark Wilkinson CASE CASE bc.BVADR6 WHEN '' THEN bc.BVNAME ELSE bc.BVADR6 END
CASE COALESCE(cg.cgrp,bc.bvname) ------Alecia Latini-------------------------------
WHEN 'THE HOME DEPOT' THEN '90005' WHEN 'DO IT BEST' THEN '90006'
WHEN 'DO IT BEST' THEN '90005' WHEN 'ACE HARDWARE' THEN '90006'
WHEN 'ACE HARDWARE' THEN '90005' WHEN 'ALDI' THEN '90006'
WHEN 'ALDI' THEN '90005' WHEN 'AMAZON.COM' THEN '90006'
WHEN 'AMAZON.COM' THEN '90005' WHEN 'GARDEN RIDGE CORP' THEN '90006' --AKA "At Home"
WHEN 'GARDEN RIDGE CORP' THEN '90005' WHEN 'TRUE VALUE' THEN '90006'
--all other retail goes to Doran Marable WHEN 'WAYFAIR' THEN '90006'
ELSE '50200' WHEN 'GRIFFIN' THEN '90006'
END WHEN 'WAL-MART' THEN '90006'
END ------Tony Landino--------------------------------
ELSE WHEN 'THE HOME DEPOT' THEN '50802'
CASE WHEN COALESCE(avming,awming) = 'B52' THEN WHEN 'FRED MEYER' THEN '50802'
'PW' WHEN 'MENARDS' THEN '50802'
--gdir, ndir go to bill-to rep WHEN 'KROGER' THEN '50802'
ELSE WHEN 'OCEAN STATE JOBBERS' THEN '50802'
CASE WHEN bc.bvclas IN ('GDIR','NDIR') THEN WHEN 'AURORA WHOLESALE' THEN '50802'
bc.bvsalm WHEN 'LEON KORRAL' THEN '50802'
ELSE --all other retail goes to Doran Marable-----------
sc.bvsalm ELSE '50200'
END END
END END
END --minor group b52 goes to dedicated rep
,'' ELSE
) CASE WHEN i.MING = 'B52' THEN
) 'PW'
LEFT OUTER JOIN SI ON --gdir, ndir go to bill-to rep
SI.BSMJCD = COALESCE(m.avmajs,p.awmajs) ELSE
AND SI.BSMNCD = COALESCE(m.avmins,p.awmins) CASE WHEN bc.bvclas IN ('GDIR','NDIR') THEN
LEFT OUTER JOIN SJ ON bc.bvsalm
SJ.BSMJCD = COALESCE(m.avmajs,p.awmajs) ELSE
LEFT OUTER JOIN LGDAT.MAJG ON sc.bvsalm
BQGRP = COALESCE(m.avmajg,p.awmajg) END
LEFT OUTER JOIN LGDAT.MMGP ON END
BRMGRP = COALESCE(m.avming,p.awming) END
AND BRGRP = COALESCE(m.avmajg,p.awmajg) )
LEFT OUTER JOIN lgdat.icstm im ON LEFT OUTER JOIN lgdat.icstm im ON
im.cgpart = b.part im.cgpart = b.part
AND im.cgplnt = a.v6plnt AND im.cgplnt = i.dplt
LEFT OUTER JOIN lgdat.icstp ip ON LEFT OUTER JOIN lgdat.icstp ip ON
ip.chpart = b.part ip.chpart = b.part
AND ip.chplnt = a.v6plnt AND ip.chplnt = i.dplt
LEFT OUTER JOIN lgdat.icstr ir ON LEFT OUTER JOIN lgdat.icstr ir ON
ir.y0part = b.part ir.y0part = b.part
AND ir.y0plnt = a.v6plnt AND ir.y0plnt = i.dplt
LEFT OUTER JOIN lgdat.plnt ON LEFT OUTER JOIN lgdat.plnt ON
yaplnt = a.v6plnt yaplnt = i.dplt
LEFT OUTER JOIN copr ON LEFT OUTER JOIN copr ON
copr.comp = yacomp::text copr.comp = yacomp::text
LEFT OUTER JOIN rlarp.ffcret cx ON LEFT OUTER JOIN rlarp.ffcret cx ON
cx.perd = '1910' cx.perd = '2008'
AND cx.rtyp = 'MA' AND cx.rtyp = 'MA'
AND cx.fcur = copr.curr AND cx.fcur = copr.curr
AND cx.tcur = 'US' AND cx.tcur = 'US'
LEFT OUTER JOIN rlarp.ffcret rx ON LEFT OUTER JOIN rlarp.ffcret rx ON
rx.perd = '1910' rx.perd = '2008'
AND rx.rtyp = 'MA' AND rx.rtyp = 'MA'
AND rx.fcur = bc.bvcurr AND rx.fcur = bc.bvcurr
AND rx.tcur = 'US' AND rx.tcur = 'US'
LEFT OUTER JOIN LGDAT.ADRS AD ON
AD.QZADR = plnt."yaadr#"
) )
/*
,clone_part_meta AS (
SELECT
b.majg --master data
,b.ming --master data
,b.majs --master data
,b.mins --master data
,b.gldc --master data
,b.glec --master data
,b.harm --master data
,b.clss --master data
,b.brand --master data
,b.assc --master data
,b.segm
,b.majg_descr
,b.ming_descr
,b.majs_descr
,b.mins_descr
,b.quota_rep
,sum(fb_val_loc * r_rate) agg
FROM
rlarp.osm_fcpool b
WHERE
-----------------scenario----------------------------
where_clause
--probably dont want to include adjustments that have blown away volume and good sources of dating info
-----------------additional params-------------------
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate
GROUP BY
b.majg --master data
,b.ming --master data
,b.majs --master data
,b.mins --master data
,b.gldc --master data
,b.glec --master data
,b.harm --master data
,b.clss --master data
,b.brand --master data
,b.assc --master data
,b.segm
,b.majg_descr
,b.ming_descr
,b.majs_descr
,b.mins_descr
,b.quota_rep
ORDER BY
agg desc
)
*/
, ins AS ( , ins AS (
INSERT INTO rlarp.osm_fcpool SELECT * FROM final RETURNING * INSERT INTO rlarp.osm_pool SELECT * FROM final RETURNING *
) )
,insagg AS ( ,insagg AS (
SELECT SELECT
bill_cust_descr ---------customer info-----------------
,billto_group bill_cust_descr
,ship_cust_descr ,billto_group
,shipto_group ,ship_cust_descr
,quota_rep_descr ,shipto_group
,director_descr ,quota_rep_descr
,segm ,director
,mod_chan ,segm
,mod_chansub ,chan
,majg_descr ,chansub
,ming_descr ---------product info------------------
,majs_descr ,majg_descr
,mins_descr ,ming_descr
,brand ,majs_descr
,part_family ,mins_descr
,part_group --,brand
,branding --,part_family
,color ,part_group
,part_descr ,branding
,order_season --,color
,order_month ,part_descr
,ship_season ---------dates-------------------------
,ship_month ,order_season
,request_season ,order_month
,request_month ,ship_season
,promo ,ship_month
,version ,request_season
,iter ,request_month
,sum(value_loc) value_loc ,promo
,sum(value_usd) value_usd ,version
,sum(cost_loc) cost_loc ,iter
,sum(cost_usd) cost_usd --------values-------------------------
,sum(units) units ,sum(value_loc) value_loc
FROM ,sum(value_usd) value_usd
ins ,sum(cost_loc) cost_loc
GROUP BY ,sum(cost_usd) cost_usd
bill_cust_descr ,sum(units) units
,billto_group FROM
,ship_cust_descr ins
,shipto_group GROUP BY
,quota_rep_descr ---------customer info-----------------
,director_descr bill_cust_descr
,segm ,billto_group
,mod_chan ,ship_cust_descr
,mod_chansub ,shipto_group
,majg_descr ,quota_rep_descr
,ming_descr ,director
,majs_descr ,segm
,mins_descr ,chan
,brand ,chansub
,part_family ---------product info------------------
,part_group ,majg_descr
,branding ,ming_descr
,color ,majs_descr
,part_descr ,mins_descr
,order_season --,brand
,order_month --,part_family
,ship_season ,part_group
,ship_month ,branding
,request_season --,color
,request_month ,part_descr
,promo ---------dates-------------------------
,version ,order_season
,iter ,order_month
,ship_season
,ship_month
,request_season
,request_month
,promo
,version
,iter
) )
SELECT json_agg(row_to_json(insagg)) x from insagg SELECT json_agg(row_to_json(insagg)) x from insagg

View File

@ -1,157 +1,83 @@
WITH WITH
target AS (select target_increment incr) target AS (select target_increment incr)
,basemix AS ( ,basemix AS (
SELECT SELECT
plnt ---master data fspr
,0::numeric(11,0) "ddord#" --0 ,plnt ---master data
,0::numeric(11,0) "dditm#" --0
,0::numeric(11,0) "fgbol#" --0
,0::numeric(11,0) "fgent#" --0
,0::numeric(9,0) "diinv#" --0
,0::numeric(3,0) "dilin#" --0
,promo --history date mix ,promo --history date mix
,null::text return_reas --0
,terms ,terms
,''::text custpo --0 ,bill_cust_descr --history cust mix
,'I' dhincr --0 ,ship_cust_descr --history cust mix
,null::numeric diext ,dsm
,null::numeric ditdis ,quota_rep_descr --master data
,null::date dcodat --calculated date mix ,director
,null::date ddqdat --calculated date mix ,billto_group --master data
,null::date dcmdat --calculated date mix ,shipto_group
,null::date dhidat --calculated date mix
,null::text fspr --calculated date mix
,remit_to --master data
,bill_class --master data
,bill_cust --history cust mix
,bill_rep --master data
,bill_terr --master data
,ship_class --master data
,ship_cust --history cust mix
,ship_rep --master data
,ship_terr --master data
,quota_rep --master data
,account --master data
,shipgrp --master data
,geo --master data
,chan --master data ,chan --master data
,orig_ctry --master data ,chansub
,orig_prov --master data ,chan_retail
,orig_post --master data ,part
,dest_ctry --master data ,part_descr
,dest_prov --master data ,part_group
,dest_post --master data ,branding
,part --history part mix ,majg_descr
,ord_gldc --master data ,ming_descr
,majg --master data ,majs_descr
,ming --master data ,mins_descr
,majs --master data ,segm
,mins --master data
,gldc --master data
,glec --master data
,harm --master data
,clss --master data
,brand --master data
,assc --master data
,fs_line --master data ,fs_line --master data
,r_currency --history cust mix ,r_currency --history cust mix
,r_rate --master data ,r_rate --master data
,c_currency --master data ,c_currency --master data
,c_rate --master data ,c_rate --master data
,0::numeric(15,5) ddqtoi --0 ,sum(coalesce(units,0)) units --history value
,0::numeric(15,5) ddqtsi --0 ,sum(coalesce(value_loc,0)) value_loc --history value
,0::numeric(15,5) fgqshp --0 ,sum(coalesce(value_usd,0)) value_usd --0
,0::numeric(15,5) diqtsh --0 ,sum(coalesce(cost_loc,0)) cost_loc --history part mix
,sum(coalesce(fb_qty,0)) fb_qty --history value ,sum(coalesce(cost_usd,0)) cost_usd
,sum(coalesce(fb_cst_loc,0)) fb_cst_loc --history part mix
,sum(coalesce(fb_cst_loc_cur,0)) fb_cst_loc_cur --master data
,sum(coalesce(fb_cst_loc_fut,0)) fb_cst_loc_fut --master data
,sum(coalesce(fb_val_loc,0)) fb_val_loc --history value
,sum(coalesce(fb_val_loc_pl,0)) fb_val_loc_pl --0
,calc_status --0 ,calc_status --0
,flag --0 ,flag --0
,orderdate --history date mix ,order_date --history date mix
,requestdate --history date mix
,shipdate --history date mix
,adj_orderdate --history
,adj_requestdate --history
,adj_shipdate --history
,'b20' "version" --calculated
,'adjustment' iter --calculated
---------------ui columns-------------------------
,order_season
,order_month ,order_month
,ship_season ,order_season
,ship_month ,request_date --history date mix
,request_season
,request_month ,request_month
,part_descr ,request_season
,part_family ,ship_date --history date mix
,part_group ,ship_month
,branding ,ship_season
,color
,segm
,bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,mod_chan
,mod_chansub
,quota_rep_descr
,director_descr
,null value_loc
,null value_usd
,null cost_loc
,null cost_usd
,null units
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
WHERE WHERE
-----------------scenario---------------------------- -----------------scenario----------------------------
where_clause where_clause
-----------------additional params------------------- -----------------additional params-------------------
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate AND order_date <= ship_date
GROUP BY GROUP BY
plnt ---master data fspr
,promo ,plnt ---master data
,promo --history date mix
,terms ,terms
,remit_to --master data ,bill_cust_descr --history cust mix
,bill_class --master data ,ship_cust_descr --history cust mix
,bill_cust --history cust mix ,dsm
,bill_rep --master data ,quota_rep_descr --master data
,bill_terr --master data ,director
,ship_class --master data ,billto_group --master data
,ship_cust --history cust mix ,shipto_group
,ship_rep --master data
,ship_terr --master data
,quota_rep --master data
,account --master data
,shipgrp --master data
,geo --master data
,chan --master data ,chan --master data
,orig_ctry --master data ,chansub
,orig_prov --master data ,chan_retail
,orig_post --master data ,part
,dest_ctry --master data ,part_descr
,dest_prov --master data ,part_group
,dest_post --master data ,branding
,part --history part mix ,majg_descr
,ord_gldc --master data ,ming_descr
,majg --master data ,majs_descr
,ming --master data ,mins_descr
,majs --master data ,segm
,mins --master data
,gldc --master data
,glec --master data
,harm --master data
,clss --master data
,brand --master data
,assc --master data
,fs_line --master data ,fs_line --master data
,r_currency --history cust mix ,r_currency --history cust mix
,r_rate --master data ,r_rate --master data
@ -159,51 +85,29 @@ SELECT
,c_rate --master data ,c_rate --master data
,calc_status --0 ,calc_status --0
,flag --0 ,flag --0
,orderdate --history date mix ,order_date --history date mix
,requestdate --history date mix
,shipdate --history date mix
,adj_orderdate --history
,adj_requestdate --history
,adj_shipdate --history
---------------ui columns-------------------------
,order_season
,order_month ,order_month
,ship_season ,order_season
,ship_month ,request_date --history date mix
,request_season
,request_month ,request_month
,part_descr ,request_season
,part_family ,ship_date --history date mix
,part_group ,ship_month
,branding ,ship_season
,color
,segm
,bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,mod_chan
,mod_chansub
,quota_rep_descr
,director_descr
) )
,scale AS ( ,scale AS (
SELECT SELECT
(SELECT incr::numeric FROM target) incr (SELECT incr::numeric FROM target) incr
,(SELECT sum(fb_val_loc * r_rate) FROM basemix) base ,(SELECT sum(value_loc * r_rate) FROM basemix) base
,CASE WHEN (SELECT sum(fb_val_loc * r_rate) FROM basemix) = 0 THEN ,CASE WHEN (SELECT sum(value_loc * r_rate) FROM basemix) = 0 THEN
0 0
ELSE ELSE
(SELECT incr::numeric FROM target)/(SELECT sum(fb_val_loc * r_rate) FROM basemix) (SELECT incr::numeric FROM target)/(SELECT sum(value_loc * r_rate) FROM basemix)
END factor END factor
,CASE WHEN (SELECT sum(fb_val_loc * r_rate) FROM basemix) = 0 THEN ,CASE WHEN (SELECT sum(value_loc * r_rate) FROM basemix) = 0 THEN
CASE WHEN ((SELECT incr::numeric FROM target) - (SELECT sum(fb_val_loc * r_rate) FROM basemix)) <> 0 THEN CASE WHEN ((SELECT incr::numeric FROM target) - (SELECT sum(value_loc * r_rate) FROM basemix)) <> 0 THEN
--if the base value is -0- but the target value hasn't been achieved, derive a price to apply --if the base value is -0- but the target value hasn't been achieved, derive a price to apply
((SELECT incr::numeric FROM target) - (SELECT sum(fb_val_loc * r_rate) FROM basemix))/(SELECT sum(fb_qty) FROM basemix) ((SELECT incr::numeric FROM target) - (SELECT sum(value_loc * r_rate) FROM basemix))/(SELECT sum(units) FROM basemix)
ELSE ELSE
0 0
END END
@ -211,193 +115,143 @@ SELECT
0 0
END mod_price END mod_price
) )
,log AS (
INSERT INTO rlarp.osm_log(doc) SELECT $$replace_iterdef$$::jsonb doc RETURNING *
)
,final AS ( ,final AS (
SELECT SELECT
b.plnt --master data fspr
,b."ddord#" --0 ,plnt ---master data
,b."dditm#" --0 ,promo --history date mix
,b."fgbol#" --0 ,terms
,b."fgent#" --0 ,bill_cust_descr --history cust mix
,b."diinv#" --0 ,ship_cust_descr --history cust mix
,b."dilin#" --0 ,dsm
,b.promo --history date mix ,quota_rep_descr --master data
,b.return_reas --0 ,director
,b.terms --history cust mix ,billto_group --master data
,b.custpo --0 ,shipto_group
,b.dhincr --0 ,chan --master data
,b.diext --0 ,chansub
,b.ditdis --0 ,chan_retail
,b.dcodat --calculated date mix ,part
,b.ddqdat --calculated date mix ,part_descr
,b.dcmdat --calculated date mix ,part_group
,b.dhidat --calculated date mix ,branding
,b.fspr --calculated date mix ,majg_descr
,b.remit_to --master data ,ming_descr
,b.bill_class --master data ,majs_descr
,b.bill_cust --history cust mix ,mins_descr
,b.bill_rep --master data ,segm
,b.bill_terr --master data ,fs_line --master data
,b.ship_class --master data ,r_currency --history cust mix
,b.ship_cust --history cust mix ,r_rate --master data
,b.ship_rep --master data ,c_currency --master data
,b.ship_terr --master data ,c_rate --master data
,b.quota_rep --master data ,0::numeric units
,b.account --master data ,(CASE WHEN s.factor = 0 THEN b.units * s.mod_price/b.r_rate ELSE b.value_loc*s.factor END)::numeric value_loc
,b.shipgrp --master data ,(CASE WHEN s.factor = 0 THEN b.units * s.mod_price ELSE b.value_usd*s.factor END)::numeric value_usd
,b.geo --master data ,0::numeric cost_loc
,b.chan --master data ,0::numeric cost_usd
,b.orig_ctry --master data ,calc_status --0
,b.orig_prov --master data ,flag --0
,b.orig_post --master data ,order_date --history date mix
,b.dest_ctry --master data ,order_month
,b.dest_prov --master data ,order_season
,b.dest_post --master data ,request_date --history date mix
,b.part --history part mix ,request_month
,b.ord_gldc --master data ,request_season
,b.majg --master data ,ship_date --history date mix
,b.ming --master data ,ship_month
,b.majs --master data ,ship_season
,b.mins --master data ,'replace_version' "version"
,b.gldc --master data ,'replace_source'||' price' iter
,b.glec --master data ,log.id
,b.harm --master data ,log.doc->>'comment' "comment"
,b.clss --master data ,log.doc->>'type' module
,b.brand --master data FROM
,b.assc --master data basemix b
,b.fs_line --master data CROSS JOIN scale s
,b.r_currency --history cust mix CROSS JOIN log
,b.r_rate --master data WHERE
,b.c_currency --master data s.factor <> 0 or s.mod_price <> 0
,b.c_rate --master data
,b.ddqtoi --0
,b.ddqtsi --0
,b.fgqshp --0
,b.diqtsh --0
,0 fb_qty
,0 fb_cst_loc
,0 fb_cst_loc_cur
,0 fb_cst_loc_fut
--,b.fb_val_loc*s.factor fb_val_loc
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price/b.r_rate ELSE b.fb_val_loc*s.factor END)::numeric fb_val_loc
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price/b.r_rate ELSE b.fb_val_loc_pl*s.factor END)::numeric fb_val_loc_pl
--,b.fb_val_loc_pl*s.factor fb_val_loc_pl
,b.calc_status --0
,b.flag --0
,b.orderdate
,b.requestdate
,b.shipdate
,b.adj_orderdate
,b.adj_requestdate
,b.adj_shipdate
,'replace_version' "version" --calculated
,'replace_source'||' price' iter --calculated
-----------------------ui columns--------------------------------
,'replace_iterdet' iterdet
,$$replace_iterdef$$::jsonb iterdef
,b.order_season
,b.order_month
,b.ship_season
,b.ship_month
,b.request_season
,b.request_month
,b.part_descr
,b.part_family
,b.part_group
,b.branding
,b.color
,b.segm
,b.bill_cust_descr
,b.billto_group
,b.ship_cust_descr
,b.shipto_group
,b.majg_descr
,b.ming_descr
,b.majs_descr
,b.mins_descr
,b.mod_chan
,b.mod_chansub
,b.quota_rep_descr
,b.director_descr
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price/b.r_rate ELSE b.fb_val_loc*s.factor END)::numeric value_loc
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price ELSE b.fb_val_loc*s.factor*r_rate END)::numeric value_usd
,0 cost_loc
,0 cost_usd
,0 units
FROM
basemix b
CROSS JOIN scale s
WHERE
s.factor <> 0 or s.mod_price <> 0
) )
--select sum(value_usd), count(*) from final --select sum(value_usd), count(*) from final
, ins AS ( , ins AS (
INSERT INTO rlarp.osm_fcpool SELECT * FROM final RETURNING * INSERT INTO rlarp.osm_pool SELECT * FROM final RETURNING *
) )
,insagg AS ( ,insagg AS (
SELECT SELECT
bill_cust_descr ---------customer info-----------------
,billto_group bill_cust_descr
,ship_cust_descr ,billto_group
,shipto_group ,ship_cust_descr
,quota_rep_descr ,shipto_group
,director_descr ,quota_rep_descr
,segm ,director
,mod_chan ,segm
,mod_chansub ,chan
,majg_descr ,chansub
,ming_descr ---------product info------------------
,majs_descr ,majg_descr
,mins_descr ,ming_descr
,brand ,majs_descr
,part_family ,mins_descr
,part_group --,brand
,branding --,part_family
,color ,part_group
,part_descr ,branding
,order_season --,color
,order_month ,part_descr
,ship_season ---------dates-------------------------
,ship_month ,order_season
,request_season ,order_month
,request_month ,ship_season
,promo ,ship_month
,version ,request_season
,iter ,request_month
,sum(value_loc) value_loc ,promo
,sum(value_usd) value_usd ,version
,sum(cost_loc) cost_loc ,iter
,sum(cost_usd) cost_usd --------values-------------------------
,sum(units) units ,sum(value_loc) value_loc
FROM ,sum(value_usd) value_usd
ins ,sum(cost_loc) cost_loc
GROUP BY ,sum(cost_usd) cost_usd
bill_cust_descr ,sum(units) units
,billto_group FROM
,ship_cust_descr ins
,shipto_group GROUP BY
,quota_rep_descr ---------customer info-----------------
,director_descr bill_cust_descr
,segm ,billto_group
,mod_chan ,ship_cust_descr
,mod_chansub ,shipto_group
,majg_descr ,quota_rep_descr
,ming_descr ,director
,majs_descr ,segm
,mins_descr ,chan
,brand ,chansub
,part_family ---------product info------------------
,part_group ,majg_descr
,branding ,ming_descr
,color ,majs_descr
,part_descr ,mins_descr
,order_season --,brand
,order_month --,part_family
,ship_season ,part_group
,ship_month ,branding
,request_season --,color
,request_month ,part_descr
,promo ---------dates-------------------------
,version ,order_season
,iter ,order_month
,ship_season
,ship_month
,request_season
,request_month
,promo
,version
,iter
) )
SELECT json_agg(row_to_json(insagg)) x from insagg SELECT json_agg(row_to_json(insagg)) x from insagg

View File

@ -2,18 +2,17 @@ WITH
target AS (select incr_qty qincr) target AS (select incr_qty qincr)
,testv AS ( ,testv AS (
SELECT SELECT
sum(fb_qty) tot sum(units) tot
,sum(fb_qty) FILTER (WHERE iter = 'copy') base ,sum(units) FILTER (WHERE iter = 'copy') base
,sum(fb_qty) FILTER (WHERE iterdef->>'type' = 'new basket') newpart ,sum(units) FILTER (WHERE module = 'new basket') newpart
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool p
WHERE WHERE
-----------------scenario---------------------------- -----------------scenario----------------------------
where_clause where_clause
-----------------additional params------------------- -----------------additional params-------------------
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate AND order_date <= ship_date
) )
,flagv AS ( ,flagv AS (
SELECT SELECT
@ -38,115 +37,53 @@ target AS (select incr_qty qincr)
) )
--ever need receive a target of -0- qty but value <> 0? --ever need receive a target of -0- qty but value <> 0?
,basemix AS ( ,basemix AS (
SELECT SELECT
plnt ---master data fspr
,0::numeric(11,0) "ddord#" --0 ,plnt ---master data
,0::numeric(11,0) "dditm#" --0
,0::numeric(11,0) "fgbol#" --0
,0::numeric(11,0) "fgent#" --0
,0::numeric(9,0) "diinv#" --0
,0::numeric(3,0) "dilin#" --0
,promo --history date mix ,promo --history date mix
,null::text return_reas --0
,terms ,terms
,''::text custpo --0 ,bill_cust_descr --history cust mix
,'I' dhincr --0 ,ship_cust_descr --history cust mix
,null::numeric diext ,dsm
,null::numeric ditdis ,quota_rep_descr --master data
,null::date dcodat --calculated date mix ,director
,null::date ddqdat --calculated date mix ,billto_group --master data
,null::date dcmdat --calculated date mix ,shipto_group
,null::date dhidat --calculated date mix
,null::text fspr --calculated date mix
,remit_to --master data
,bill_class --master data
,bill_cust --history cust mix
,bill_rep --master data
,bill_terr --master data
,ship_class --master data
,ship_cust --history cust mix
,ship_rep --master data
,ship_terr --master data
,quota_rep --master data
,account --master data
,shipgrp --master data
,geo --master data
,chan --master data ,chan --master data
,orig_ctry --master data ,chansub
,orig_prov --master data ,chan_retail
,orig_post --master data ,part
,dest_ctry --master data ,part_descr
,dest_prov --master data ,part_group
,dest_post --master data ,branding
,part --history part mix ,majg_descr
,ord_gldc --master data ,ming_descr
,majg --master data ,majs_descr
,ming --master data ,mins_descr
,majs --master data ,segm
,mins --master data
,gldc --master data
,glec --master data
,harm --master data
,clss --master data
,brand --master data
,assc --master data
,fs_line --master data ,fs_line --master data
,r_currency --history cust mix ,r_currency --history cust mix
,r_rate --master data ,r_rate --master data
,c_currency --master data ,c_currency --master data
,c_rate --master data ,c_rate --master data
,0::numeric(15,5) ddqtoi --0 ,sum(coalesce(units,0)) units --history value
,0::numeric(15,5) ddqtsi --0 ,sum(coalesce(value_loc,0)) value_loc --history value
,0::numeric(15,5) fgqshp --0 ,sum(coalesce(value_usd,0)) value_usd --0
,0::numeric(15,5) diqtsh --0 ,sum(coalesce(cost_loc,0)) cost_loc --history part mix
,sum(coalesce(fb_qty,0)) fb_qty --history value ,sum(coalesce(cost_usd,0)) cost_usd
,sum(coalesce(fb_cst_loc,0)) fb_cst_loc --history part mix
,sum(coalesce(fb_cst_loc_cur,0)) fb_cst_loc_cur --master data
,sum(coalesce(fb_cst_loc_fut,0)) fb_cst_loc_fut --master data
,sum(coalesce(fb_val_loc,0)) fb_val_loc --history value
,sum(coalesce(fb_val_loc_pl,0)) fb_val_loc_pl --0
,calc_status --0 ,calc_status --0
,flag --0 ,flag --0
,orderdate --history date mix ,order_date --history date mix
,requestdate --history date mix
,shipdate --history date mix
,adj_orderdate --history
,adj_requestdate --history
,adj_shipdate --history
,null::text "version" --calculated
,null::text iter --calculated
---------------ui columns-------------------------
,order_season
,order_month ,order_month
,ship_season ,order_season
,ship_month ,request_date --history date mix
,request_season
,request_month ,request_month
,part_descr ,request_season
,part_family ,ship_date --history date mix
,part_group ,ship_month
,branding ,ship_season
,color
,segm
,bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,mod_chan
,mod_chansub
,quota_rep_descr
,director_descr
,null value_loc
,null value_usd
,null cost_loc
,null cost_usd
,null units
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
WHERE WHERE
-----------------scenario---------------------------- -----------------scenario----------------------------
where_clause where_clause
@ -154,46 +91,34 @@ SELECT
AND CASE (SELECT flag FROM flagv) AND CASE (SELECT flag FROM flagv)
WHEN 'scale all' THEN true WHEN 'scale all' THEN true
WHEN 'scale copy' THEN iter = 'copy' WHEN 'scale copy' THEN iter = 'copy'
WHEN 'scale new part' THEN iterdef->>'type' = 'new basket' WHEN 'scale new part' THEN module = 'new basket'
END END
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate AND order_date <= ship_date
GROUP BY GROUP BY
plnt ---master data fspr
,promo ,plnt ---master data
,promo --history date mix
,terms ,terms
,remit_to --master data ,bill_cust_descr --history cust mix
,bill_class --master data ,ship_cust_descr --history cust mix
,bill_cust --history cust mix ,dsm
,bill_rep --master data ,quota_rep_descr --master data
,bill_terr --master data ,director
,ship_class --master data ,billto_group --master data
,ship_cust --history cust mix ,shipto_group
,ship_rep --master data
,ship_terr --master data
,quota_rep --master data
,account --master data
,shipgrp --master data
,geo --master data
,chan --master data ,chan --master data
,orig_ctry --master data ,chansub
,orig_prov --master data ,chan_retail
,orig_post --master data ,part
,dest_ctry --master data ,part_descr
,dest_prov --master data ,part_group
,dest_post --master data ,branding
,part --history part mix ,majg_descr
,ord_gldc --master data ,ming_descr
,majg --master data ,majs_descr
,ming --master data ,mins_descr
,majs --master data ,segm
,mins --master data
,gldc --master data
,glec --master data
,harm --master data
,clss --master data
,brand --master data
,assc --master data
,fs_line --master data ,fs_line --master data
,r_currency --history cust mix ,r_currency --history cust mix
,r_rate --master data ,r_rate --master data
@ -201,229 +126,159 @@ SELECT
,c_rate --master data ,c_rate --master data
,calc_status --0 ,calc_status --0
,flag --0 ,flag --0
,orderdate --history date mix ,order_date --history date mix
,requestdate --history date mix ,order_month
,shipdate --history date mix ,order_season
,adj_orderdate --history ,request_date --history date mix
,adj_requestdate --history ,request_month
,adj_shipdate --history ,request_season
---------------ui columns------------------------- ,ship_date --history date mix
,ship_month
,ship_season
)
--SELECT * FROM basemix
,scale AS (
SELECT
(SELECT qincr::numeric FROM target) incr
,(SELECT sum(value_loc *r_rate) FROM basemix) base
,(SELECT qincr FROM target)/(SELECT SUM(units) FROM basemix) factor
)
--select * from scale
,log AS (
INSERT INTO rlarp.osm_log(doc) SELECT $$replace_iterdef$$::jsonb doc RETURNING *
)
,final AS (
SELECT
fspr
,plnt ---master data
,promo --history date mix
,terms
,bill_cust_descr --history cust mix
,ship_cust_descr --history cust mix
,dsm
,quota_rep_descr --master data
,director
,billto_group --master data
,shipto_group
,chan --master data
,chansub
,chan_retail
,part
,part_descr
,part_group
,branding
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,segm
,fs_line --master data
,r_currency --history cust mix
,r_rate --master data
,c_currency --master data
,c_rate --master data
,units*s.factor
,value_loc*s.factor value_loc
,value_usd*s.factor value_usd
,cost_loc*s.factor cost_loc
,cost_usd*s.factor cost_usd
,calc_status --0
,flag --0
,order_date --history date mix
,order_month
,order_season
,request_date --history date mix
,request_month
,request_season
,ship_date --history date mix
,ship_month
,ship_season
,'replace_version' "version"
,'replace_source'||' volume' iter
,log.id
,log.doc->>'comment' "comment"
,log.doc->>'type' module
FROM
basemix b
CROSS JOIN scale s
CROSS JOIN log
)
--select sum(value_usd), count(*) from final
, ins AS (
INSERT INTO rlarp.osm_pool SELECT * FROM final RETURNING *
)
,insagg AS (
SELECT
---------customer info-----------------
bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,quota_rep_descr
,director
,segm
,chan
,chansub
---------product info------------------
,majg_descr
,ming_descr
,majs_descr
,mins_descr
--,brand
--,part_family
,part_group
,branding
--,color
,part_descr
---------dates-------------------------
,order_season ,order_season
,order_month ,order_month
,ship_season ,ship_season
,ship_month ,ship_month
,request_season ,request_season
,request_month ,request_month
,part_descr ,promo
,part_family ,version
,part_group ,iter
,branding --------values-------------------------
,color ,sum(value_loc) value_loc
,segm ,sum(value_usd) value_usd
,bill_cust_descr ,sum(cost_loc) cost_loc
,sum(cost_usd) cost_usd
,sum(units) units
FROM
ins
GROUP BY
---------customer info-----------------
bill_cust_descr
,billto_group ,billto_group
,ship_cust_descr ,ship_cust_descr
,shipto_group ,shipto_group
,quota_rep_descr
,director
,segm
,chan
,chansub
---------product info------------------
,majg_descr ,majg_descr
,ming_descr ,ming_descr
,majs_descr ,majs_descr
,mins_descr ,mins_descr
,mod_chan --,brand
,mod_chansub --,part_family
,quota_rep_descr ,part_group
,director_descr ,branding
) --,color
--SELECT * FROM basemix ,part_descr
,scale AS ( ---------dates-------------------------
SELECT ,order_season
(SELECT qincr::numeric FROM target) incr ,order_month
,(SELECT sum(fb_val_loc *r_rate) FROM basemix) base ,ship_season
,(SELECT qincr FROM target)/(SELECT SUM(fb_qty) FROM basemix) factor ,ship_month
) ,request_season
--select * from scale ,request_month
,final AS ( ,promo
SELECT ,version
b.plnt --master data ,iter
,b."ddord#" --0
,b."dditm#" --0
,b."fgbol#" --0
,b."fgent#" --0
,b."diinv#" --0
,b."dilin#" --0
,b.promo --history date mix
,b.return_reas --0
,b.terms --history cust mix
,b.custpo --0
,b.dhincr --0
,b.diext --0
,b.ditdis --0
,b.dcodat --calculated date mix
,b.ddqdat --calculated date mix
,b.dcmdat --calculated date mix
,b.dhidat --calculated date mix
,b.fspr --calculated date mix
,b.remit_to --master data
,b.bill_class --master data
,b.bill_cust --history cust mix
,b.bill_rep --master data
,b.bill_terr --master data
,b.ship_class --master data
,b.ship_cust --history cust mix
,b.ship_rep --master data
,b.ship_terr --master data
,b.quota_rep --master data
,b.account --master data
,b.shipgrp --master data
,b.geo --master data
,b.chan --master data
,b.orig_ctry --master data
,b.orig_prov --master data
,b.orig_post --master data
,b.dest_ctry --master data
,b.dest_prov --master data
,b.dest_post --master data
,b.part --history part mix
,b.ord_gldc --master data
,b.majg --master data
,b.ming --master data
,b.majs --master data
,b.mins --master data
,b.gldc --master data
,b.glec --master data
,b.harm --master data
,b.clss --master data
,b.brand --master data
,b.assc --master data
,b.fs_line --master data
,b.r_currency --history cust mix
,b.r_rate --master data
,b.c_currency --master data
,b.c_rate --master data
,b.ddqtoi --0
,b.ddqtsi --0
,b.fgqshp --0
,b.diqtsh --0
,b.fb_qty*s.factor fb_qty
,b.fb_cst_loc*s.factor fb_cst_loc
,b.fb_cst_loc_cur*s.factor fb_cst_loc_cur
,b.fb_cst_loc_fut*s.factor fb_cst_loc_fut
,b.fb_val_loc*s.factor fb_val_loc
,b.fb_val_loc_pl*s.factor fb_val_loc_pl
,b.calc_status --0
,b.flag --0
,b.orderdate
,b.requestdate
,b.shipdate
,b.adj_orderdate
,b.adj_requestdate
,b.adj_shipdate
,'replace_version' "version" --calculated
,'replace_source'||' volume' iter
-----------------------ui columns--------------------------------
,'replace_iterdet' iterdet
,$$replace_iterdef$$::jsonb iterdef
,b.order_season
,b.order_month
,b.ship_season
,b.ship_month
,b.request_season
,b.request_month
,b.part_descr
,b.part_family
,b.part_group
,b.branding
,b.color
,b.segm
,b.bill_cust_descr
,b.billto_group
,b.ship_cust_descr
,b.shipto_group
,b.majg_descr
,b.ming_descr
,b.majs_descr
,b.mins_descr
,b.mod_chan
,b.mod_chansub
,b.quota_rep_descr
,b.director_descr
,(b.fb_val_loc*s.factor)::numeric value_loc
,(b.fb_val_loc*s.factor*r_rate)::numeric value_usd
,(b.fb_cst_loc*s.factor)::numeric cost_loc
,(b.fb_cst_loc*s.factor*c_rate)::numeric cost_usd
,(b.fb_qty*s.factor)::numeric units
FROM
basemix b
CROSS JOIN scale s
)
--select sum(value_usd), count(*) from final
, ins AS (
INSERT INTO rlarp.osm_fcpool SELECT * FROM final RETURNING *
)
,insagg AS (
SELECT
bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,quota_rep_descr
,director_descr
,segm
,mod_chan
,mod_chansub
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,brand
,part_family
,part_group
,branding
,color
,part_descr
,order_season
,order_month
,ship_season
,ship_month
,request_season
,request_month
,promo
,version
,iter
,sum(value_loc) value_loc
,sum(value_usd) value_usd
,sum(cost_loc) cost_loc
,sum(cost_usd) cost_usd
,sum(units) units
FROM
ins
GROUP BY
bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,quota_rep_descr
,director_descr
,segm
,mod_chan
,mod_chansub
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,brand
,part_family
,part_group
,branding
,color
,part_descr
,order_season
,order_month
,ship_season
,ship_month
,request_season
,request_month
,promo
,version
,iter
) )
SELECT json_agg(row_to_json(insagg)) x from insagg SELECT json_agg(row_to_json(insagg)) x from insagg

View File

@ -2,17 +2,17 @@ WITH
target AS (select target_vol vincr, target_prc pincr) target AS (select target_vol vincr, target_prc pincr)
,testv AS ( ,testv AS (
SELECT SELECT
sum(fb_qty) tot sum(units) tot
,sum(fb_qty) FILTER (WHERE iter = 'copy') base ,sum(units) FILTER (WHERE iter = 'copy') base
,sum(fb_qty) FILTER (WHERE iterdef->>'type' = 'new basket') newpart ,sum(units) FILTER (WHERE module = 'new basket') newpart
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
WHERE WHERE
-----------------scenario---------------------------- -----------------scenario----------------------------
where_clause where_clause
-----------------additional params------------------- -----------------additional params-------------------
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate AND order_date <= ship_date
) )
,flagv AS ( ,flagv AS (
@ -38,114 +38,52 @@ target AS (select target_vol vincr, target_prc pincr)
) )
,basemix AS ( ,basemix AS (
SELECT SELECT
plnt ---master data fspr
,0::numeric(11,0) "ddord#" --0 ,plnt ---master data
,0::numeric(11,0) "dditm#" --0
,0::numeric(11,0) "fgbol#" --0
,0::numeric(11,0) "fgent#" --0
,0::numeric(9,0) "diinv#" --0
,0::numeric(3,0) "dilin#" --0
,promo --history date mix ,promo --history date mix
,null::text return_reas --0
,terms ,terms
,''::text custpo --0 ,bill_cust_descr --history cust mix
,'I' dhincr --0 ,ship_cust_descr --history cust mix
,null::numeric diext ,dsm
,null::numeric ditdis ,quota_rep_descr --master data
,null::date dcodat --calculated date mix ,director
,null::date ddqdat --calculated date mix ,billto_group --master data
,null::date dcmdat --calculated date mix ,shipto_group
,null::date dhidat --calculated date mix
,null::text fspr --calculated date mix
,remit_to --master data
,bill_class --master data
,bill_cust --history cust mix
,bill_rep --master data
,bill_terr --master data
,ship_class --master data
,ship_cust --history cust mix
,ship_rep --master data
,ship_terr --master data
,quota_rep --master data
,account --master data
,shipgrp --master data
,geo --master data
,chan --master data ,chan --master data
,orig_ctry --master data ,chansub
,orig_prov --master data ,chan_retail
,orig_post --master data ,part
,dest_ctry --master data ,part_descr
,dest_prov --master data ,part_group
,dest_post --master data ,branding
,part --history part mix ,majg_descr
,ord_gldc --master data ,ming_descr
,majg --master data ,majs_descr
,ming --master data ,mins_descr
,majs --master data ,segm
,mins --master data
,gldc --master data
,glec --master data
,harm --master data
,clss --master data
,brand --master data
,assc --master data
,fs_line --master data ,fs_line --master data
,r_currency --history cust mix ,r_currency --history cust mix
,r_rate --master data ,r_rate --master data
,c_currency --master data ,c_currency --master data
,c_rate --master data ,c_rate --master data
,0::numeric(15,5) ddqtoi --0 ,sum(coalesce(units,0)) units --history value
,0::numeric(15,5) ddqtsi --0 ,sum(coalesce(value_loc,0)) value_loc --history value
,0::numeric(15,5) fgqshp --0 ,sum(coalesce(value_usd,0)) value_usd --0
,0::numeric(15,5) diqtsh --0 ,sum(coalesce(cost_loc,0)) cost_loc --history part mix
,sum(coalesce(fb_qty,0)) fb_qty --history value ,sum(coalesce(cost_usd,0)) cost_usd
,sum(coalesce(fb_cst_loc,0)) fb_cst_loc --history part mix
,sum(coalesce(fb_cst_loc_cur,0)) fb_cst_loc_cur --master data
,sum(coalesce(fb_cst_loc_fut,0)) fb_cst_loc_fut --master data
,sum(coalesce(fb_val_loc,0)) fb_val_loc --history value
,sum(coalesce(fb_val_loc_pl,0)) fb_val_loc_pl --0
,calc_status --0 ,calc_status --0
,flag --0 ,flag --0
,orderdate --history date mix ,order_date --history date mix
,requestdate --history date mix
,shipdate --history date mix
,adj_orderdate --history
,adj_requestdate --history
,adj_shipdate --history
,null::text "version" --calculated
,null::text iter --calculated
---------------ui columns-------------------------
,order_season
,order_month ,order_month
,ship_season ,order_season
,ship_month ,request_date --history date mix
,request_season
,request_month ,request_month
,part_descr ,request_season
,part_family ,ship_date --history date mix
,part_group ,ship_month
,branding ,ship_season
,color
,segm
,bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,mod_chan
,mod_chansub
,quota_rep_descr
,director_descr
,null value_loc
,null value_usd
,null cost_loc
,null cost_usd
,null units
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
WHERE WHERE
-----------------scenario---------------------------- -----------------scenario----------------------------
where_clause where_clause
@ -153,46 +91,34 @@ target AS (select target_vol vincr, target_prc pincr)
AND CASE (SELECT flag FROM flagv) AND CASE (SELECT flag FROM flagv)
WHEN 'scale all' THEN true WHEN 'scale all' THEN true
WHEN 'scale copy' THEN iter = 'copy' WHEN 'scale copy' THEN iter = 'copy'
WHEN 'scale new part' THEN iterdef->>'type' = 'new basket' WHEN 'scale new part' THEN module = 'new basket'
END END
AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments AND calc_status||flag <> 'CLOSEDREMAINDER' --exclude short ships when building order adjustments
AND adj_orderdate <= adj_shipdate AND order_date <= ship_date
GROUP BY GROUP BY
plnt ---master data fspr
,promo ,plnt ---master data
,promo --history date mix
,terms ,terms
,remit_to --master data ,bill_cust_descr --history cust mix
,bill_class --master data ,ship_cust_descr --history cust mix
,bill_cust --history cust mix ,dsm
,bill_rep --master data ,quota_rep_descr --master data
,bill_terr --master data ,director
,ship_class --master data ,billto_group --master data
,ship_cust --history cust mix ,shipto_group
,ship_rep --master data
,ship_terr --master data
,quota_rep --master data
,account --master data
,shipgrp --master data
,geo --master data
,chan --master data ,chan --master data
,orig_ctry --master data ,chansub
,orig_prov --master data ,chan_retail
,orig_post --master data ,part
,dest_ctry --master data ,part_descr
,dest_prov --master data ,part_group
,dest_post --master data ,branding
,part --history part mix ,majg_descr
,ord_gldc --master data ,ming_descr
,majg --master data ,majs_descr
,ming --master data ,mins_descr
,majs --master data ,segm
,mins --master data
,gldc --master data
,glec --master data
,harm --master data
,clss --master data
,brand --master data
,assc --master data
,fs_line --master data ,fs_line --master data
,r_currency --history cust mix ,r_currency --history cust mix
,r_rate --master data ,r_rate --master data
@ -200,174 +126,97 @@ target AS (select target_vol vincr, target_prc pincr)
,c_rate --master data ,c_rate --master data
,calc_status --0 ,calc_status --0
,flag --0 ,flag --0
,orderdate --history date mix ,order_date --history date mix
,requestdate --history date mix
,shipdate --history date mix
,adj_orderdate --history
,adj_requestdate --history
,adj_shipdate --history
---------------ui columns-------------------------
,order_season
,order_month ,order_month
,ship_season ,order_season
,ship_month ,request_date --history date mix
,request_season
,request_month ,request_month
,part_descr ,request_season
,part_family ,ship_date --history date mix
,part_group ,ship_month
,branding ,ship_season
,color
,segm
,bill_cust_descr
,billto_group
,ship_cust_descr
,shipto_group
,majg_descr
,ming_descr
,majs_descr
,mins_descr
,mod_chan
,mod_chansub
,quota_rep_descr
,director_descr
) )
,vscale AS ( ,vscale AS (
SELECT SELECT
(SELECT vincr::numeric FROM target) incr (SELECT vincr::numeric FROM target) incr
,(SELECT sum(fb_qty)::numeric FROM basemix) base ,(SELECT sum(units)::numeric FROM basemix) base
,(SELECT vincr::numeric FROM target)/(SELECT sum(fb_qty)::numeric FROM basemix) factor ,(SELECT vincr::numeric FROM target)/(SELECT sum(units)::numeric FROM basemix) factor
) )
--select * from vscale --select * from vscale
,log AS (
INSERT INTO rlarp.osm_log(doc) SELECT $$replace_iterdef$$::jsonb doc RETURNING *
)
,volume AS ( ,volume AS (
SELECT SELECT
b.plnt --master data fspr
,b."ddord#" --0 ,plnt ---master data
,b."dditm#" --0 ,promo --history date mix
,b."fgbol#" --0 ,terms
,b."fgent#" --0 ,bill_cust_descr --history cust mix
,b."diinv#" --0 ,ship_cust_descr --history cust mix
,b."dilin#" --0 ,dsm
,b.promo --history date mix ,quota_rep_descr --master data
,b.return_reas --0 ,director
,b.terms --history cust mix ,billto_group --master data
,b.custpo --0 ,shipto_group
,b.dhincr --0 ,chan --master data
,b.diext --0 ,chansub
,b.ditdis --0 ,chan_retail
,b.dcodat --calculated date mix ,part
,b.ddqdat --calculated date mix ,part_descr
,b.dcmdat --calculated date mix ,part_group
,b.dhidat --calculated date mix ,branding
,b.fspr --calculated date mix ,majg_descr
,b.remit_to --master data ,ming_descr
,b.bill_class --master data ,majs_descr
,b.bill_cust --history cust mix ,mins_descr
,b.bill_rep --master data ,segm
,b.bill_terr --master data ,fs_line --master data
,b.ship_class --master data ,r_currency --history cust mix
,b.ship_cust --history cust mix ,r_rate --master data
,b.ship_rep --master data ,c_currency --master data
,b.ship_terr --master data ,c_rate --master data
,b.quota_rep --master data ,units*s.factor units
,b.account --master data ,value_loc*s.factor value_loc
,b.shipgrp --master data ,value_usd*s.factor value_usd
,b.geo --master data ,cost_loc*s.factor cost_loc
,b.chan --master data ,cost_usd*s.factor cost_usd
,b.orig_ctry --master data ,calc_status --0
,b.orig_prov --master data ,flag --0
,b.orig_post --master data ,order_date --history date mix
,b.dest_ctry --master data ,order_month
,b.dest_prov --master data ,order_season
,b.dest_post --master data ,request_date --history date mix
,b.part --history part mix ,request_month
,b.ord_gldc --master data ,request_season
,b.majg --master data ,ship_date --history date mix
,b.ming --master data ,ship_month
,b.majs --master data ,ship_season
,b.mins --master data ,'replace_version' "version"
,b.gldc --master data ,'replace_source'||' volume' iter
,b.glec --master data ,log.id
,b.harm --master data ,log.doc->>'comment' "comment"
,b.clss --master data ,log.doc->>'type' module
,b.brand --master data FROM
,b.assc --master data basemix b
,b.fs_line --master data CROSS JOIN vscale s
,b.r_currency --history cust mix CROSS JOIN log
,b.r_rate --master data
,b.c_currency --master data
,b.c_rate --master data
,b.ddqtoi --0
,b.ddqtsi --0
,b.fgqshp --0
,b.diqtsh --0
,b.fb_qty*s.factor fb_qty
,b.fb_cst_loc*s.factor fb_cst_loc
,b.fb_cst_loc_cur*s.factor fb_cst_loc_cur
,b.fb_cst_loc_fut*s.factor fb_cst_loc_fut
,b.fb_val_loc*s.factor fb_val_loc
,b.fb_val_loc_pl*s.factor fb_val_loc_pl
,b.calc_status --0
,b.flag --0
,b.orderdate
,b.requestdate
,b.shipdate
,b.adj_orderdate
,b.adj_requestdate
,b.adj_shipdate
,'replace_version' "version" --calculated
,'replace_source'||' volume' iter
-----------------------ui columns--------------------------------
,'replace_iterdet' iterdet
,$$replace_iterdef$$::jsonb iterdef
,b.order_season
,b.order_month
,b.ship_season
,b.ship_month
,b.request_season
,b.request_month
,b.part_descr
,b.part_family
,b.part_group
,b.branding
,b.color
,b.segm
,b.bill_cust_descr
,b.billto_group
,b.ship_cust_descr
,b.shipto_group
,b.majg_descr
,b.ming_descr
,b.majs_descr
,b.mins_descr
,b.mod_chan
,b.mod_chansub
,b.quota_rep_descr
,b.director_descr
,(b.fb_val_loc*s.factor)::numeric value_loc
,(b.fb_val_loc*s.factor*r_rate)::numeric value_usd
,(b.fb_cst_loc*s.factor)::numeric cost_loc
,(b.fb_cst_loc*s.factor*c_rate)::numeric cost_usd
,(b.fb_qty*s.factor)::numeric units
FROM
basemix b
CROSS JOIN vscale s
) )
,pscale AS ( ,pscale AS (
SELECT SELECT
(SELECT pincr::numeric FROM target) incr (SELECT pincr::numeric FROM target) incr
,(SELECT sum(fb_val_loc * r_rate) FROM volume) base ,(SELECT sum(value_loc * r_rate) FROM volume) base
,CASE WHEN (SELECT sum(fb_val_loc * r_rate) FROM volume) = 0 THEN ,CASE WHEN (SELECT sum(value_loc * r_rate) FROM volume) = 0 THEN
--if the base value is -0- scaling will not work, need to generate price, factor goes to -0- --if the base value is -0- scaling will not work, need to generate price, factor goes to -0-
0 0
ELSE ELSE
--if the target $amount is not achieved, adjust further --if the target $amount is not achieved, adjust further
((SELECT pincr::numeric FROM target)-(SELECT sum(fb_val_loc * r_rate) FROM volume))/(SELECT sum(fb_val_loc * r_rate) FROM volume) ((SELECT pincr::numeric FROM target)-(SELECT sum(value_loc * r_rate) FROM volume))/(SELECT sum(value_loc * r_rate) FROM volume)
END factor END factor
,CASE WHEN (SELECT sum(fb_val_loc * r_rate) FROM volume) = 0 THEN ,CASE WHEN (SELECT sum(value_loc * r_rate) FROM volume) = 0 THEN
CASE WHEN ((SELECT pincr::numeric FROM target) - (SELECT sum(fb_val_loc * r_rate) FROM volume)) <> 0 THEN CASE WHEN ((SELECT pincr::numeric FROM target) - (SELECT sum(value_loc * r_rate) FROM volume)) <> 0 THEN
--if the base value is -0- but the target value hasn't been achieved, derive a price to apply --if the base value is -0- but the target value hasn't been achieved, derive a price to apply
((SELECT pincr::numeric FROM target) - (SELECT sum(fb_val_loc * r_rate) FROM volume))/(SELECT sum(fb_qty) FROM volume) ((SELECT pincr::numeric FROM target) - (SELECT sum(value_loc * r_rate) FROM volume))/(SELECT sum(units) FROM volume)
ELSE ELSE
0 0
END END
@ -378,191 +227,138 @@ target AS (select target_vol vincr, target_prc pincr)
--select * from pscale --select * from pscale
,pricing AS ( ,pricing AS (
SELECT SELECT
b.plnt --master data fspr
,b."ddord#" --0 ,plnt ---master data
,b."dditm#" --0 ,promo --history date mix
,b."fgbol#" --0 ,terms
,b."fgent#" --0 ,bill_cust_descr --history cust mix
,b."diinv#" --0 ,ship_cust_descr --history cust mix
,b."dilin#" --0 ,dsm
,b.promo --history date mix ,quota_rep_descr --master data
,b.return_reas --0 ,director
,b.terms --history cust mix ,billto_group --master data
,b.custpo --0 ,shipto_group
,b.dhincr --0 ,chan --master data
,b.diext --0 ,chansub
,b.ditdis --0 ,chan_retail
,b.dcodat --calculated date mix ,part
,b.ddqdat --calculated date mix ,part_descr
,b.dcmdat --calculated date mix ,part_group
,b.dhidat --calculated date mix ,branding
,b.fspr --calculated date mix ,majg_descr
,b.remit_to --master data ,ming_descr
,b.bill_class --master data ,majs_descr
,b.bill_cust --history cust mix ,mins_descr
,b.bill_rep --master data ,segm
,b.bill_terr --master data ,fs_line --master data
,b.ship_class --master data ,r_currency --history cust mix
,b.ship_cust --history cust mix ,r_rate --master data
,b.ship_rep --master data ,c_currency --master data
,b.ship_terr --master data ,c_rate --master data
,b.quota_rep --master data ,0::numeric units
,b.account --master data ,(CASE WHEN s.factor = 0 THEN b.units * s.mod_price/b.r_rate ELSE b.value_loc*s.factor END)::numeric value_loc
,b.shipgrp --master data ,(CASE WHEN s.factor = 0 THEN b.units * s.mod_price ELSE b.value_usd*s.factor END)::numeric value_usd
,b.geo --master data ,0::numeric cost_loc
,b.chan --master data ,0::numeric cost_usd
,b.orig_ctry --master data ,calc_status --0
,b.orig_prov --master data ,flag --0
,b.orig_post --master data ,order_date --history date mix
,b.dest_ctry --master data ,order_month
,b.dest_prov --master data ,order_season
,b.dest_post --master data ,request_date --history date mix
,b.part --history part mix ,request_month
,b.ord_gldc --master data ,request_season
,b.majg --master data ,ship_date --history date mix
,b.ming --master data ,ship_month
,b.majs --master data ,ship_season
,b.mins --master data ,'replace_version' "version"
,b.gldc --master data ,'replace_source'||' price' iter
,b.glec --master data ,log.id
,b.harm --master data ,log.doc->>'comment' "comment"
,b.clss --master data ,log.doc->>'type' module
,b.brand --master data
,b.assc --master data
,b.fs_line --master data
,b.r_currency --history cust mix
,b.r_rate --master data
,b.c_currency --master data
,b.c_rate --master data
,b.ddqtoi --0
,b.ddqtsi --0
,b.fgqshp --0
,b.diqtsh --0
,0 fb_qty
,0 fb_cst_loc
,0 fb_cst_loc_cur
,0 fb_cst_loc_fut
--,b.fb_val_loc*s.factor fb_val_loc
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price/b.r_rate ELSE b.fb_val_loc*s.factor END)::numeric fb_val_loc
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price/b.r_rate ELSE b.fb_val_loc_pl*s.factor END)::numeric fb_val_loc_pl
--,b.fb_val_loc_pl*s.factor fb_val_loc_pl
,b.calc_status --0
,b.flag --0
,b.orderdate
,b.requestdate
,b.shipdate
,b.adj_orderdate
,b.adj_requestdate
,b.adj_shipdate
,'replace_version' "version" --calculated
,'replace_source'||' price' iter
-----------------------ui columns--------------------------------
,'replace_iterdet' iterdet
,$$replace_iterdef$$::jsonb iterdef
,b.order_season
,b.order_month
,b.ship_season
,b.ship_month
,b.request_season
,b.request_month
,b.part_descr
,b.part_family
,b.part_group
,b.branding
,b.color
,b.segm
,b.bill_cust_descr
,b.billto_group
,b.ship_cust_descr
,b.shipto_group
,b.majg_descr
,b.ming_descr
,b.majs_descr
,b.mins_descr
,b.mod_chan
,b.mod_chansub
,b.quota_rep_descr
,b.director_descr
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price/b.r_rate ELSE b.fb_val_loc*s.factor END)::numeric value_loc
,(CASE WHEN s.factor = 0 THEN b.fb_qty * s.mod_price ELSE b.fb_val_loc*s.factor*b.r_rate END)::numeric value_usd
,0 cost_loc
,0 cost_usd
,0 units
FROM FROM
volume b volume b
CROSS JOIN pscale s CROSS JOIN pscale s
CROSS JOIN log
WHERE WHERE
s.factor <> 0 or s.mod_price <> 0 s.factor <> 0 or s.mod_price <> 0
) )
--select sum(value_usd), sum(fb_qty) from pricing --select sum(value_usd), sum(units) from pricing
, ins AS ( , ins AS (
INSERT INTO rlarp.osm_fcpool (SELECT * FROM pricing UNION ALL SELECT * FROM volume) RETURNING * INSERT INTO rlarp.osm_pool (SELECT * FROM pricing UNION ALL SELECT * FROM volume) RETURNING *
) )
,insagg AS ( ,insagg AS (
SELECT SELECT
bill_cust_descr ---------customer info-----------------
,billto_group bill_cust_descr
,ship_cust_descr ,billto_group
,shipto_group ,ship_cust_descr
,quota_rep_descr ,shipto_group
,director_descr ,quota_rep_descr
,segm ,director
,mod_chan ,segm
,mod_chansub ,chan
,majg_descr ,chansub
,ming_descr ---------product info------------------
,majs_descr ,majg_descr
,mins_descr ,ming_descr
,brand ,majs_descr
,part_family ,mins_descr
,part_group --,brand
,branding --,part_family
,color ,part_group
,part_descr ,branding
,order_season --,color
,order_month ,part_descr
,ship_season ---------dates-------------------------
,ship_month ,order_season
,request_season ,order_month
,request_month ,ship_season
,promo ,ship_month
,version ,request_season
,iter ,request_month
,sum(value_loc) value_loc ,promo
,sum(value_usd) value_usd ,version
,sum(cost_loc) cost_loc ,iter
,sum(cost_usd) cost_usd --------values-------------------------
,sum(units) units ,sum(value_loc) value_loc
FROM ,sum(value_usd) value_usd
ins ,sum(cost_loc) cost_loc
GROUP BY ,sum(cost_usd) cost_usd
bill_cust_descr ,sum(units) units
,billto_group FROM
,ship_cust_descr ins
,shipto_group GROUP BY
,quota_rep_descr ---------customer info-----------------
,director_descr bill_cust_descr
,segm ,billto_group
,mod_chan ,ship_cust_descr
,mod_chansub ,shipto_group
,majg_descr ,quota_rep_descr
,ming_descr ,director
,majs_descr ,segm
,mins_descr ,chan
,brand ,chansub
,part_family ---------product info------------------
,part_group ,majg_descr
,branding ,ming_descr
,color ,majs_descr
,part_descr ,mins_descr
,order_season --,brand
,order_month --,part_family
,ship_season ,part_group
,ship_month ,branding
,request_season --,color
,request_month ,part_descr
,promo ---------dates-------------------------
,version ,order_season
,iter ,order_month
,ship_season
,ship_month
,request_season
,request_month
,promo
,version
,iter
) )
SELECT json_agg(row_to_json(insagg)) x from insagg SELECT json_agg(row_to_json(insagg)) x from insagg

View File

@ -5,18 +5,18 @@ mseq AS (
SELECT * FROM SELECT * FROM
( (
VALUES VALUES
('Jun',1) ('01 - Jun',1)
,('Jul',2) ,('02 - Jul',2)
,('Aug',3) ,('03 - Aug',3)
,('Sep',4) ,('04 - Sep',4)
,('Oct',5) ,('05 - Oct',5)
,('Nov',6) ,('06 - Nov',6)
,('Dec',7) ,('07 - Dec',7)
,('Jan',8) ,('08 - Jan',8)
,('Feb',9) ,('09 - Feb',9)
,('Mar',10) ,('10 - Mar',10)
,('Apr',11) ,('11 - Apr',11)
,('May',12) ,('12 - May',12)
) x(m,s) ) x(m,s)
) )
@ -33,10 +33,10 @@ SELECT
,SUM(units) units ,SUM(units) units
,SUM(value_usd) value_usd ,SUM(value_usd) value_usd
FROM FROM
rlarp.osm_fcpool rlarp.osm_pool
WHERE WHERE
where_clause where_clause
AND order_season IN (2019,2020) AND order_season IN (2020,2021)
GROUP BY GROUP BY
order_season order_season
,order_month ,order_month
@ -94,14 +94,14 @@ GROUP BY
SELECT SELECT
order_month order_month
,seq ,seq
,SUM(units) FILTER (WHERE order_season = 2019) "2019 qty" ,SUM(units) FILTER (WHERE order_season = 2020) "2020 qty"
,SUM(units) FILTER (WHERE order_season = 2020 AND iter IN ('copy','short ship','bad_ship')) "2020 base qty" ,SUM(units) FILTER (WHERE order_season = 2021 AND iter IN ('copy','short ship','bad_ship')) "2021 base qty"
,SUM(units) FILTER (WHERE order_season = 2020 AND iter NOT IN ('copy','short ship','bad_ship')) "2020 adj qty" ,SUM(units) FILTER (WHERE order_season = 2021 AND iter NOT IN ('copy','short ship','bad_ship')) "2021 adj qty"
,SUM(units) FILTER (WHERE order_season = 2020) "2020 tot qty" ,SUM(units) FILTER (WHERE order_season = 2021) "2021 tot qty"
,SUM(value_usd) FILTER (WHERE order_season = 2019) "2019 value_usd" ,SUM(value_usd) FILTER (WHERE order_season = 2020) "2020 value_usd"
,SUM(value_usd) FILTER (WHERE order_season = 2020 AND iter IN ('copy','short ship','bad_ship')) "2020 base value_usd" ,SUM(value_usd) FILTER (WHERE order_season = 2021 AND iter IN ('copy','short ship','bad_ship')) "2021 base value_usd"
,SUM(value_usd) FILTER (WHERE order_season = 2020 AND iter NOT IN ('copy','short ship','bad_ship')) "2020 adj value_usd" ,SUM(value_usd) FILTER (WHERE order_season = 2021 AND iter NOT IN ('copy','short ship','bad_ship')) "2021 adj value_usd"
,SUM(value_usd) FILTER (WHERE order_season = 2020) "2020 tot value_usd" ,SUM(value_usd) FILTER (WHERE order_season = 2021) "2021 tot value_usd"
FROM FROM
months months
GROUP BY GROUP BY
@ -113,14 +113,14 @@ GROUP BY
,mlist AS ( ,mlist AS (
SELECT SELECT
mseq.m order_month mseq.m order_month
,"2019 qty" ,"2020 qty"
,"2020 base qty" ,"2021 base qty"
,"2020 adj qty" ,"2021 adj qty"
,"2020 tot qty" ,"2021 tot qty"
,"2019 value_usd" ,"2020 value_usd"
,"2020 base value_usd" ,"2021 base value_usd"
,"2020 adj value_usd" ,"2021 adj value_usd"
,"2020 tot value_usd" ,"2021 tot value_usd"
FROM FROM
mseq mseq
LEFT OUTER JOIN mpvt ON LEFT OUTER JOIN mpvt ON