From c4bb5acd1612372e987b30a8e91b7cdafebab702 Mon Sep 17 00:00:00 2001 From: Paul Trowbridge Date: Wed, 20 Sep 2017 00:12:37 -0400 Subject: [PATCH] expirement with different formats and add a receipt --- build_json.xlsx | Bin 10330 -> 17979 bytes event_log.md | 8 +++++++- new_format.pgsql | 20 ++++++++++++++++++-- ~$build_json.xlsx | Bin 0 -> 165 bytes 4 files changed, 25 insertions(+), 3 deletions(-) create mode 100644 ~$build_json.xlsx diff --git a/build_json.xlsx b/build_json.xlsx index 0117acb767086ccddf32d4363ebb49b1ff4590e1..a2f93fe8737aae3c3861edac5d2499bbb74ff72b 100644 GIT binary patch delta 11597 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 E0T{bdtpET3 delta 3983 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 trigger based on insert adds to GL -> gl adds to balance based on GL trigger - ? how is fiscal period determined \ No newline at end of file + ? how is fiscal period determined + + +log gl format +* the gl array is an array of object + * each gl line is initially a full json object + * extract demanded fields (account, amount) and delete from the json but retain the rest as the supporting items \ No newline at end of file diff --git a/new_format.pgsql b/new_format.pgsql index 0b9f4a4..9cd33fd 100644 --- a/new_format.pgsql +++ b/new_format.pgsql @@ -1,5 +1,21 @@ WITH j AS ( SELECT - JSONB_PRETTY($${"vendor":"Drug Mart","date":"2017-08-20","instrument":"Discover Card","module":"MJE_O","offset":"dcard","total":18.25,"item":[{"item":"Green Chili","amount":1.49,"reason":"food"},{"item":"Black Beans","amount":1.6,"reason":"food"},{"item":"Distilled Water","amount":7.12,"reason":"food"},{"item":"Fruit Preservative","amount":3.99,"reason":"food"},{"item":"Watch Battery","amount":3.79,"reason":"supplies"},{"item":"Sales Tax","amount":"0.26","reason":"taxes"}],"gl":[{"gl":"food","amount":1.49,"reason":"food","item":"Green Chili"},{"gl":"food","amount":1.6,"reason":"food","item":"Black Beans"},{"gl":"food","amount":7.12,"reason":"food","item":"Distilled Water"},{"gl":"food","amount":3.99,"reason":"food","item":"Fruit Preservative"},{"gl":"supplies","amount":3.79,"reason":"supplies","item":"Watch Battery"},{"gl":"taxes","amount":"0.26","reason":"taxes","item":"Sales Tax"},{"gl":"dcard","amount":-1.49,"reason":"food","item":"Green Chili"},{"gl":"dcard","amount":-1.6,"reason":"food","item":"Black Beans"},{"gl":"dcard","amount":-7.12,"reason":"food","item":"Distilled Water"},{"gl":"dcard","amount":-3.99,"reason":"food","item":"Fruit Preservative"},{"gl":"dcard","amount":-3.79,"reason":"supplies","item":"Watch Battery"},{"gl":"dcard","amount":-0.26,"reason":"taxes","item":"Sales Tax"}]}$$::JSONB) as r + $${"vendor":"Acme","date":"9/19/2017","instrument":"Discover Card","module":"MJE_O","offset":"dcard","total":127.66,"item":[{"item":"sun chips","amt":3.29,"account":"food","reason":"chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"cheetos paws","amt":3.69,"account":"food","reason":"chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"jif","amt":4.99,"account":"food","reason":"peanut butter","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"jif whips","amt":3.99,"account":"food","reason":"peanut butter","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"jif","amt":4.99,"account":"food","reason":"peanut butter","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"goya chipotle pepp","amt":2.29,"account":"food","reason":"chili peppers","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"quick oats","amt":4.69,"account":"food","reason":"oats","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"quick oats","amt":4.69,"account":"food","reason":"oats","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"sara lee artesano","amt":2.99,"account":"food","reason":"bread","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"dan lgt yog","amt":3.29,"account":"food","reason":"yogurt","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"bananas","amt":3.7,"account":"food","reason":"bananas","qty":7.11,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"yellow onions","amt":2.99,"account":"food","reason":"onions","qty":3,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"orange peppers","amt":4.11,"account":"food","reason":"peppers","qty":1.03,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"asparagus","amt":5.14,"account":"food","reason":"asparagus","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"broccoli","amt":2.99,"account":"food","reason":"broccoli","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"hn fat free frank","amt":5.49,"account":"food","reason":"hot dogs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"hn fat free frank","amt":5.49,"account":"food","reason":"hot dogs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"butterscotch morsels","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"seedless grapes","amt":11.45,"account":"food","reason":"grapes","qty":2.87,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"honecrisp apples","amt":14.76,"account":"food","reason":"apples","qty":3.7,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"garlic expressions","amt":4.99,"account":"food","reason":"salad dressing","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"olivegarden dressing","amt":3.49,"account":"food","reason":"salad dressing","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"garlic expressions","amt":4.99,"account":"food","reason":"salad dressing","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"thomas cinamon bagels","amt":4.69,"account":"food","reason":"bagels","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"stawberries","amt":1.25,"account":"food","reason":"strawberries","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"stawberries","amt":1.25,"account":"food","reason":"strawberries","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"provolone cheese","amt":6.99,"account":"food","reason":"cheese","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"lemon juice","amt":1.99,"account":"food","reason":"lemon juice","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"cucumbers","amt":1.99,"account":"food","reason":"cucumbers","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"cucumbers","amt":1.99,"account":"food","reason":"cucumbers","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.7,"account":"food","reason":"chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-0.99,"account":"food","reason":"broccoli","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-8.03,"account":"food","reason":"grapes","qty":2.87,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-5.55,"account":"food","reason":"apples","qty":3.7,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"}]}$$::JSONB as r ) -select j.r->'vendor' from j \ No newline at end of file +select + a.i->>'amt', + a.i->>'account', + a.i->>'date', + a.i - '{amt,account,date}'::text[] as therest +FROM + j + LEFT JOIN LATERAL JSONB_ARRAY_ELEMENTS(j.r->'item') a(i) ON TRUE + +/* +SELECT +jsonb_pretty( +$$ +{"vendor":"Acme","date":"9/19/2017","instrument":"Discover Card","module":"MJE_O","offset":"dcard","total":127.66,"item":[{"item":"sun chips","amt":3.29,"account":"food","reason":"chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"cheetos paws","amt":3.69,"account":"food","reason":"chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"jif","amt":4.99,"account":"food","reason":"peanut butter","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"jif whips","amt":3.99,"account":"food","reason":"peanut butter","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"jif","amt":4.99,"account":"food","reason":"peanut butter","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"goya chipotle pepp","amt":2.29,"account":"food","reason":"chili peppers","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"quick oats","amt":4.69,"account":"food","reason":"oats","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"quick oats","amt":4.69,"account":"food","reason":"oats","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"sara lee artesano","amt":2.99,"account":"food","reason":"bread","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"dan lgt yog","amt":3.29,"account":"food","reason":"yogurt","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"bananas","amt":3.7,"account":"food","reason":"bananas","qty":7.11,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"yellow onions","amt":2.99,"account":"food","reason":"onions","qty":3,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"orange peppers","amt":4.11,"account":"food","reason":"peppers","qty":1.03,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"asparagus","amt":5.14,"account":"food","reason":"asparagus","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"broccoli","amt":2.99,"account":"food","reason":"broccoli","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"hn fat free frank","amt":5.49,"account":"food","reason":"hot dogs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"hn fat free frank","amt":5.49,"account":"food","reason":"hot dogs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"butterscotch morsels","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"chocolate chips","amt":3.49,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"seedless grapes","amt":11.45,"account":"food","reason":"grapes","qty":2.87,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"honecrisp apples","amt":14.76,"account":"food","reason":"apples","qty":3.7,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"garlic expressions","amt":4.99,"account":"food","reason":"salad dressing","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"olivegarden dressing","amt":3.49,"account":"food","reason":"salad dressing","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"garlic expressions","amt":4.99,"account":"food","reason":"salad dressing","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"thomas cinamon bagels","amt":4.69,"account":"food","reason":"bagels","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"stawberries","amt":1.25,"account":"food","reason":"strawberries","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"stawberries","amt":1.25,"account":"food","reason":"strawberries","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"provolone cheese","amt":6.99,"account":"food","reason":"cheese","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"lemon juice","amt":1.99,"account":"food","reason":"lemon juice","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"cucumbers","amt":1.99,"account":"food","reason":"cucumbers","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"cucumbers","amt":1.99,"account":"food","reason":"cucumbers","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"distilled water","amt":"0.89","account":"food","reason":"water","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.7,"account":"food","reason":"chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-0.99,"account":"food","reason":"broccoli","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-1.5,"account":"food","reason":"chocolate chips","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-8.03,"account":"food","reason":"grapes","qty":2.87,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"},{"item":"discount","amt":-5.55,"account":"food","reason":"apples","qty":3.7,"uom":"lbs","vendor":"Acme","date":"9/19/2017","instrument":"Discover Card"}]} +$$::jsonb +) +*/ \ No newline at end of file diff --git a/~$build_json.xlsx b/~$build_json.xlsx new file mode 100644 index 0000000000000000000000000000000000000000..a902500550089e9be0689a4469ff5866181530e1 GIT binary patch literal 165 zcmd-NNG#1!2r0@hPb$hxNl#TE4)8MsFeEaRGUPBQFoZA^G2}CpGb91&OokMObcR%* HC^aDf_q-K# literal 0 HcmV?d00001