2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
-- PostgreSQL database dump
|
|
|
|
--
|
|
|
|
|
2017-10-25 00:42:22 -04:00
|
|
|
-- Dumped from database version 10beta4
|
|
|
|
-- Dumped by pg_dump version 10beta4
|
2017-10-11 00:46:15 -04:00
|
|
|
|
|
|
|
SET statement_timeout = 0;
|
|
|
|
SET lock_timeout = 0;
|
|
|
|
SET idle_in_transaction_session_timeout = 0;
|
|
|
|
SET client_encoding = 'WIN1252';
|
|
|
|
SET standard_conforming_strings = on;
|
|
|
|
SET check_function_bodies = false;
|
|
|
|
SET client_min_messages = warning;
|
|
|
|
SET row_security = off;
|
|
|
|
|
2017-10-25 12:07:04 -04:00
|
|
|
--
|
|
|
|
-- Name: bank; Type: SCHEMA; Schema: -; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE SCHEMA bank;
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
-- Name: evt; Type: SCHEMA; Schema: -; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE SCHEMA evt;
|
|
|
|
|
|
|
|
|
|
|
|
--
|
2017-10-13 02:27:10 -04:00
|
|
|
-- Name: SCHEMA evt; Type: COMMENT; Schema: -; Owner: -
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
|
2017-10-13 02:27:10 -04:00
|
|
|
COMMENT ON SCHEMA evt IS 'events';
|
2017-10-11 00:46:15 -04:00
|
|
|
|
|
|
|
|
|
|
|
--
|
2017-10-13 02:27:10 -04:00
|
|
|
-- Name: tps; Type: SCHEMA; Schema: -; Owner: -
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
|
2017-10-13 02:27:10 -04:00
|
|
|
CREATE SCHEMA tps;
|
2017-10-11 00:46:15 -04:00
|
|
|
|
|
|
|
|
|
|
|
--
|
2017-10-13 02:27:10 -04:00
|
|
|
-- Name: SCHEMA tps; Type: COMMENT; Schema: -; Owner: -
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
|
2017-10-13 02:27:10 -04:00
|
|
|
COMMENT ON SCHEMA tps IS 'third party source';
|
2017-10-11 00:46:15 -04:00
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: plpgsql; Type: EXTENSION; Schema: -; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: EXTENSION plpgsql; Type: COMMENT; Schema: -; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
COMMENT ON EXTENSION plpgsql IS 'PL/pgSQL procedural language';
|
|
|
|
|
|
|
|
|
2017-10-25 12:07:04 -04:00
|
|
|
SET search_path = bank, pg_catalog;
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: pncc; Type: TYPE; Schema: bank; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TYPE pncc AS (
|
|
|
|
"AsOfDate" date,
|
|
|
|
"BankId" text,
|
|
|
|
"AccountNumber" text,
|
|
|
|
"AccountName" text,
|
|
|
|
"BaiControl" text,
|
|
|
|
"Currency" text,
|
|
|
|
"Transaction" text,
|
|
|
|
"Reference" text,
|
|
|
|
"Amount" numeric,
|
|
|
|
"Description" text,
|
|
|
|
"AdditionalRemittance" text
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
SET search_path = tps, pg_catalog;
|
|
|
|
|
2017-10-19 00:42:30 -04:00
|
|
|
--
|
|
|
|
-- Name: dcard; Type: TYPE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TYPE dcard AS (
|
|
|
|
"Trans. Date" date,
|
|
|
|
"Post Date" date,
|
|
|
|
"Description" text,
|
2017-10-26 20:01:26 -04:00
|
|
|
"Amount" numeric,
|
2017-10-19 00:42:30 -04:00
|
|
|
"Category" text
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: hunt; Type: TYPE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TYPE hunt AS (
|
|
|
|
"Date" date,
|
|
|
|
"Reference Number" numeric,
|
|
|
|
"Payee Name" text,
|
|
|
|
"Memo" text,
|
|
|
|
"Amount" text,
|
|
|
|
"Category Name" text
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
-- Name: srce_defn_schema; Type: TYPE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TYPE srce_defn_schema AS (
|
|
|
|
key text,
|
|
|
|
type text
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-11-02 23:51:04 -04:00
|
|
|
SET search_path = evt, pg_catalog;
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: build_hdr_item_mje_gl(jsonb); Type: FUNCTION; Schema: evt; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE FUNCTION build_hdr_item_mje_gl(_j jsonb) RETURNS jsonb
|
|
|
|
LANGUAGE plpgsql
|
|
|
|
AS $_$
|
|
|
|
DECLARE _m text;
|
|
|
|
|
|
|
|
BEGIN
|
|
|
|
|
|
|
|
--_j := $${"header":{"vendor":"Target","date":"10/12/2017","instrument":"Discover Card","module":"hdrio","total":47.74,"location":"Stow, OH","transaction":"purchase","offset":"dcard"},"item":[{"vend item":"HERBAL","amt":7.99,"account":"home supplies","item":"shampoo","reason":"hygiene"},{"vend item":"HERBAL","amt":7.99,"account":"home supplies","item":"conditioner","reason":"hygiene"},{"vend item":"BUILDING SET","amt":28.74,"account":"recreation","item":"legos","reason":"toys","qty":6,"uom":"ea"},{"vend item":"OH TAX","amt":3.02,"account":"sales tax","item":"sales tax","reason":"sales tax","rate":"0.0675"}]}$$;
|
|
|
|
|
|
|
|
WITH
|
|
|
|
j AS (
|
|
|
|
SELECT
|
|
|
|
_j jb
|
|
|
|
)
|
|
|
|
|
|
|
|
--------build a duplicating cross join table------------------
|
|
|
|
|
|
|
|
,os AS (
|
|
|
|
SELECT
|
|
|
|
flag,
|
|
|
|
sign,
|
|
|
|
x.offs
|
|
|
|
FROM
|
|
|
|
j
|
|
|
|
JOIN LATERAL
|
|
|
|
(
|
|
|
|
VALUES
|
|
|
|
('ITEM',1,null),
|
|
|
|
('OFFSET',-1,j.jb->'header'->>'offset')
|
|
|
|
) x (flag, sign, offs) ON TRUE
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
------------do the cross join against all the item elements-------------------
|
|
|
|
|
|
|
|
,build AS (
|
|
|
|
SELECT
|
|
|
|
array['item',rn::text]::text jpath
|
|
|
|
,COALESCE(os.offs,ae.e->>'account') acct
|
|
|
|
,(ae.e->>'amt')::numeric * os.sign amount
|
|
|
|
FROM
|
|
|
|
j
|
|
|
|
LEFT JOIN LATERAL JSONB_ARRAY_ELEMENTS(J.JB->'item') WITH ORDINALITY ae(e,rn) ON TRUE
|
|
|
|
CROSS JOIN os
|
|
|
|
ORDER BY
|
|
|
|
ae.rn ASC,
|
|
|
|
os.flag ASC
|
|
|
|
)
|
|
|
|
|
|
|
|
-------------re-aggregate the items into a single array point called 'gl'---------------
|
|
|
|
|
|
|
|
,agg AS (
|
|
|
|
SELECT
|
|
|
|
jsonb_build_object('gl',jsonb_agg(row_to_json(b))) gl
|
|
|
|
FROM
|
|
|
|
build b
|
|
|
|
)
|
|
|
|
|
|
|
|
------------take the new 'gl' with array key-value pair and combine it with the original---------------
|
|
|
|
|
|
|
|
SELECT
|
|
|
|
jsonb_pretty(agg.gl||j.jb)
|
|
|
|
INTO
|
|
|
|
_j
|
|
|
|
FROM
|
|
|
|
agg
|
|
|
|
CROSS JOIN j;
|
|
|
|
|
|
|
|
RETURN _j;
|
|
|
|
|
|
|
|
END
|
|
|
|
$_$;
|
|
|
|
|
|
|
|
|
2017-10-25 00:42:22 -04:00
|
|
|
SET search_path = public, pg_catalog;
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: jsonb_extract(jsonb, text[]); Type: FUNCTION; Schema: public; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE FUNCTION jsonb_extract(rec jsonb, key_list text[]) RETURNS jsonb
|
|
|
|
LANGUAGE plpgsql
|
|
|
|
AS $$
|
|
|
|
DECLARE
|
2017-10-25 12:07:04 -04:00
|
|
|
t text[];
|
2017-10-25 00:42:22 -04:00
|
|
|
j jsonb := '{}'::jsonb;
|
|
|
|
|
|
|
|
BEGIN
|
2017-10-25 12:07:04 -04:00
|
|
|
FOREACH t SLICE 1 IN ARRAY key_list LOOP
|
|
|
|
--RAISE NOTICE '%', t;
|
|
|
|
--RAISE NOTICE '%', t[1];
|
|
|
|
j := j || jsonb_build_object(t[1],rec#>t);
|
2017-10-25 00:42:22 -04:00
|
|
|
END LOOP;
|
|
|
|
RETURN j;
|
|
|
|
END;
|
|
|
|
$$;
|
|
|
|
|
|
|
|
|
|
|
|
SET search_path = tps, pg_catalog;
|
|
|
|
|
2017-10-19 17:38:58 -04:00
|
|
|
--
|
|
|
|
-- Name: jsonb_concat(jsonb, jsonb); Type: FUNCTION; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE FUNCTION jsonb_concat(state jsonb, concat jsonb) RETURNS jsonb
|
|
|
|
LANGUAGE plpgsql
|
|
|
|
AS $$
|
|
|
|
BEGIN
|
|
|
|
--RAISE notice 'state is %', state;
|
|
|
|
--RAISE notice 'concat is %', concat;
|
|
|
|
RETURN state || concat;
|
|
|
|
END;
|
|
|
|
$$;
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: jsonb_concat_obj(jsonb); Type: AGGREGATE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE AGGREGATE jsonb_concat_obj(jsonb) (
|
|
|
|
SFUNC = jsonb_concat,
|
|
|
|
STYPE = jsonb,
|
|
|
|
INITCOND = '{}'
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
SET search_path = evt, pg_catalog;
|
|
|
|
|
|
|
|
SET default_tablespace = '';
|
|
|
|
|
|
|
|
SET default_with_oids = false;
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: log; Type: TABLE; Schema: evt; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE log (
|
|
|
|
id integer NOT NULL,
|
2017-10-26 23:38:36 -04:00
|
|
|
rec jsonb,
|
|
|
|
post_stmp timestamp with time zone DEFAULT now()
|
2017-10-11 00:46:15 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: log_id_seq; Type: SEQUENCE; Schema: evt; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE log ALTER COLUMN id ADD GENERATED BY DEFAULT AS IDENTITY (
|
|
|
|
SEQUENCE NAME log_id_seq
|
|
|
|
START WITH 1
|
|
|
|
INCREMENT BY 1
|
|
|
|
NO MINVALUE
|
|
|
|
NO MAXVALUE
|
|
|
|
CACHE 1
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
SET search_path = tps, pg_catalog;
|
|
|
|
|
2017-10-19 14:13:57 -04:00
|
|
|
--
|
|
|
|
-- Name: map_rm; Type: TABLE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE map_rm (
|
|
|
|
srce text NOT NULL,
|
|
|
|
target text NOT NULL,
|
2017-10-19 17:38:58 -04:00
|
|
|
regex jsonb,
|
2017-10-19 14:13:57 -04:00
|
|
|
seq integer NOT NULL
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: map_rv; Type: TABLE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE map_rv (
|
|
|
|
srce text NOT NULL,
|
|
|
|
target text NOT NULL,
|
|
|
|
retval jsonb NOT NULL,
|
|
|
|
map jsonb
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
-- Name: srce; Type: TABLE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE srce (
|
|
|
|
srce text NOT NULL,
|
|
|
|
defn jsonb
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-13 02:27:10 -04:00
|
|
|
--
|
|
|
|
-- Name: trans; Type: TABLE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE trans (
|
|
|
|
id integer NOT NULL,
|
|
|
|
srce text,
|
|
|
|
rec jsonb,
|
2017-10-25 16:28:42 -04:00
|
|
|
parse jsonb,
|
2017-10-26 13:39:50 -04:00
|
|
|
map jsonb,
|
|
|
|
allj jsonb
|
2017-10-13 02:27:10 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: trans_id_seq; Type: SEQUENCE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE trans ALTER COLUMN id ADD GENERATED BY DEFAULT AS IDENTITY (
|
|
|
|
SEQUENCE NAME trans_id_seq
|
|
|
|
START WITH 1
|
|
|
|
INCREMENT BY 1
|
|
|
|
NO MINVALUE
|
|
|
|
NO MAXVALUE
|
|
|
|
CACHE 1
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-25 00:42:22 -04:00
|
|
|
--
|
|
|
|
-- Name: trans_log; Type: TABLE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE trans_log (
|
|
|
|
id integer NOT NULL,
|
|
|
|
info jsonb
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: trans_log_id_seq; Type: SEQUENCE; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE trans_log ALTER COLUMN id ADD GENERATED BY DEFAULT AS IDENTITY (
|
|
|
|
SEQUENCE NAME trans_log_id_seq
|
|
|
|
START WITH 1
|
|
|
|
INCREMENT BY 1
|
|
|
|
NO MINVALUE
|
|
|
|
NO MAXVALUE
|
|
|
|
CACHE 1
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
SET search_path = evt, pg_catalog;
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: log log_pkey; Type: CONSTRAINT; Schema: evt; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY log
|
|
|
|
ADD CONSTRAINT log_pkey PRIMARY KEY (id);
|
|
|
|
|
|
|
|
|
|
|
|
SET search_path = tps, pg_catalog;
|
|
|
|
|
2017-10-19 14:13:57 -04:00
|
|
|
--
|
|
|
|
-- Name: map_rm map_rm_pk; Type: CONSTRAINT; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY map_rm
|
2017-10-19 17:38:58 -04:00
|
|
|
ADD CONSTRAINT map_rm_pk PRIMARY KEY (srce, target);
|
2017-10-19 14:13:57 -04:00
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Name: map_rv map_rv_pk; Type: CONSTRAINT; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY map_rv
|
|
|
|
ADD CONSTRAINT map_rv_pk PRIMARY KEY (srce, target, retval);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
-- Name: srce srce_pkey; Type: CONSTRAINT; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY srce
|
|
|
|
ADD CONSTRAINT srce_pkey PRIMARY KEY (srce);
|
|
|
|
|
|
|
|
|
2017-10-25 00:42:22 -04:00
|
|
|
--
|
|
|
|
-- Name: trans_log trans_log_pkey; Type: CONSTRAINT; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY trans_log
|
|
|
|
ADD CONSTRAINT trans_log_pkey PRIMARY KEY (id);
|
|
|
|
|
|
|
|
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
2017-10-13 02:27:10 -04:00
|
|
|
-- Name: trans trans_pkey; Type: CONSTRAINT; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY trans
|
|
|
|
ADD CONSTRAINT trans_pkey PRIMARY KEY (id);
|
|
|
|
|
|
|
|
|
2017-10-26 13:39:50 -04:00
|
|
|
--
|
|
|
|
-- Name: trans_allj; Type: INDEX; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE INDEX trans_allj ON trans USING gin (allj);
|
|
|
|
|
|
|
|
|
2017-10-19 09:25:42 -04:00
|
|
|
--
|
|
|
|
-- Name: trans_rec; Type: INDEX; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
CREATE INDEX trans_rec ON trans USING gin (rec);
|
|
|
|
|
|
|
|
|
2017-10-19 14:13:57 -04:00
|
|
|
--
|
|
|
|
-- Name: map_rm map_rm_fk_srce; Type: FK CONSTRAINT; Schema: tps; Owner: -
|
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY map_rm
|
|
|
|
ADD CONSTRAINT map_rm_fk_srce FOREIGN KEY (srce) REFERENCES srce(srce);
|
|
|
|
|
|
|
|
|
|
|
|
--
|
2017-10-19 17:38:58 -04:00
|
|
|
-- Name: map_rv map_rv_fk_rm; Type: FK CONSTRAINT; Schema: tps; Owner: -
|
2017-10-19 14:13:57 -04:00
|
|
|
--
|
|
|
|
|
|
|
|
ALTER TABLE ONLY map_rv
|
2017-10-19 17:38:58 -04:00
|
|
|
ADD CONSTRAINT map_rv_fk_rm FOREIGN KEY (srce, target) REFERENCES map_rm(srce, target);
|
2017-10-19 14:13:57 -04:00
|
|
|
|
|
|
|
|
2017-10-13 02:27:10 -04:00
|
|
|
--
|
|
|
|
-- Name: trans trans_srce_fkey; Type: FK CONSTRAINT; Schema: tps; Owner: -
|
2017-10-11 00:46:15 -04:00
|
|
|
--
|
|
|
|
|
2017-10-13 02:27:10 -04:00
|
|
|
ALTER TABLE ONLY trans
|
|
|
|
ADD CONSTRAINT trans_srce_fkey FOREIGN KEY (srce) REFERENCES srce(srce);
|
2017-10-11 00:46:15 -04:00
|
|
|
|
|
|
|
|
|
|
|
--
|
|
|
|
-- PostgreSQL database dump complete
|
|
|
|
--
|
|
|
|
|