mirror of
https://github.com/yrzam/findb.git
synced 2025-01-04 05:02:00 +00:00
make more data historical
This commit is contained in:
parent
f0e903f509
commit
3d59720cc4
28
README.md
28
README.md
@ -97,8 +97,8 @@ Exchanges and self-transfers should be represented by two transactions, both hav
|
|||||||
```
|
```
|
||||||
asset_storage_id - points to storage and asset that took part in in transaction, direction is determined by the sign of [amount]
|
asset_storage_id - points to storage and asset that took part in in transaction, direction is determined by the sign of [amount]
|
||||||
amount - numeric, can be negative
|
amount - numeric, can be negative
|
||||||
reason_fin_asset_storage_id - (optional) financial asset, due to which transaction has occurred. This must be not manipulation with the asset itself, but the byproduct of its ownership
|
reason_fin_asset_storage_id - (optional) indirectly points to the financial asset, due to which transaction has occurred. This must be not manipulation with the asset itself, but the byproduct of its ownership
|
||||||
reason_phys_asset_id - (optional) physical asset, due to which transaction has occurred. This must be not manipulation with the asset itself, but the byproduct of its ownership
|
reason_phys_asset_ownership_id - (optional) indirectly points to the physical asset, due to which transaction has occurred. This must be not manipulation with the asset itself, but the byproduct of its ownership
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -194,13 +194,25 @@ Goals that result in financial transactions are hidden. Goal is considered accom
|
|||||||
|
|
||||||
### phys_assets (table)
|
### phys_assets (table)
|
||||||
|
|
||||||
Represents real-world assets, purchases and other non-fungible (non-interchangeable) things that a person owns. The intended use case is to track large and important assets, especially ones that generate passive gains and losses.
|
Represents real-world assets, purchases and other non-fungible (non-interchangeable) things. The intended use case is to track large and important assets, especially ones that generate passive gains and losses.
|
||||||
|
|
||||||
The asset is considered currently owned if it is neither sold (`sell_transaction_id is null`) nor naturally expired (`is_expired=0`).
|
|
||||||
|
|
||||||
> Examples: house, apartment rented for a year, commercial property, car, blockchain NFT
|
> Examples: house, apartment rented for a year, commercial property, car, blockchain NFT
|
||||||
|
|
||||||
|
|
||||||
|
### phys_asset_ownerships (table)
|
||||||
|
|
||||||
|
Tracks whether physical asset is owned by a person at a particular date. Possibly binds ownership status changes to the financial transactions.
|
||||||
|
|
||||||
|
One asset may be owned at many time periods, or not be owned at all. Asset belongs to a person if two conditions are met: `start_date<=[current date]` and `end_date>=[current_date] or end_date is null`.
|
||||||
|
|
||||||
|
```
|
||||||
|
start_date - first day of ownership
|
||||||
|
end_day - (optional) last day of ownership
|
||||||
|
buy_fin_tx_id - (optional) transaction id, if redeemed in exchange for financial asset
|
||||||
|
sell_fin_tx_id - (optional) transaction id, if sold for financial asset
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
### fin_allocation_groups (table)
|
### fin_allocation_groups (table)
|
||||||
|
|
||||||
This table sets a goal for the financial asset distribution.
|
This table sets a goal for the financial asset distribution.
|
||||||
@ -209,12 +221,12 @@ Each asset & storage (`fin_assets_storages`) from your portfolio can reference a
|
|||||||
|
|
||||||
```
|
```
|
||||||
target share - a desired fraction of all your assets that the group should take. This may be any non-negative number
|
target share - a desired fraction of all your assets that the group should take. This may be any non-negative number
|
||||||
|
start_date - since that day a rule is appled
|
||||||
|
end_date - optional, the last day to be covered by the rule
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
This table is not historical.
|
> Examples: allocation group "CASH" should have a 5% target share in 2025 Q2
|
||||||
|
|
||||||
> Examples: allocation group "CASH" should have a 5% target share
|
|
||||||
|
|
||||||
|
|
||||||
### current_fin_allocation (view)
|
### current_fin_allocation (view)
|
||||||
|
135
schema.sql
135
schema.sql
@ -22,7 +22,10 @@ CREATE TABLE "balances" (
|
|||||||
CREATE TABLE "fin_allocation_groups" (
|
CREATE TABLE "fin_allocation_groups" (
|
||||||
"id" INTEGER NOT NULL,
|
"id" INTEGER NOT NULL,
|
||||||
"name" TEXT NOT NULL UNIQUE,
|
"name" TEXT NOT NULL UNIQUE,
|
||||||
"target_share" NUMERIC NOT NULL DEFAULT 0, priority int,
|
"target_share" NUMERIC NOT NULL DEFAULT 0,
|
||||||
|
"start_date" NUMERIC NOT NULL,
|
||||||
|
"end_date" INTEGER,
|
||||||
|
"priority" INTEGER UNIQUE,
|
||||||
PRIMARY KEY("id")
|
PRIMARY KEY("id")
|
||||||
);
|
);
|
||||||
CREATE TABLE "fin_asset_rates" (
|
CREATE TABLE "fin_asset_rates" (
|
||||||
@ -89,22 +92,29 @@ CREATE TABLE "fin_transactions" (
|
|||||||
"amount" NUMERIC NOT NULL,
|
"amount" NUMERIC NOT NULL,
|
||||||
"category_id" INTEGER NOT NULL,
|
"category_id" INTEGER NOT NULL,
|
||||||
"reason_fin_asset_storage_id" INTEGER,
|
"reason_fin_asset_storage_id" INTEGER,
|
||||||
"reason_phys_asset_id" INTEGER,
|
"reason_phys_asset_ownership_id" INTEGER,
|
||||||
PRIMARY KEY("id"),
|
FOREIGN KEY("category_id") REFERENCES "fin_transaction_categories"("id"),
|
||||||
FOREIGN KEY("reason_phys_asset_id") REFERENCES "phys_assets"("id"),
|
|
||||||
FOREIGN KEY("reason_fin_asset_storage_id") REFERENCES "fin_assets_storages"("id"),
|
FOREIGN KEY("reason_fin_asset_storage_id") REFERENCES "fin_assets_storages"("id"),
|
||||||
FOREIGN KEY("category_id") REFERENCES "fin_transaction_categories"("id")
|
FOREIGN KEY("reason_phys_asset_ownership_id") REFERENCES "phys_asset_ownerships"("id"),
|
||||||
|
PRIMARY KEY("id")
|
||||||
|
);
|
||||||
|
CREATE TABLE "phys_asset_ownerships" (
|
||||||
|
"id" INTEGER NOT NULL,
|
||||||
|
"asset_id" INTEGER NOT NULL,
|
||||||
|
"start_date" NUMERIC NOT NULL,
|
||||||
|
"end_date" NUMERIC,
|
||||||
|
"buy_fin_tx_id" INTEGER,
|
||||||
|
"sell_fin_tx_id" INTEGER,
|
||||||
|
FOREIGN KEY("sell_fin_tx_id") REFERENCES "fin_transactions"("id"),
|
||||||
|
FOREIGN KEY("buy_fin_tx_id") REFERENCES "fin_transactions"("id"),
|
||||||
|
FOREIGN KEY("asset_id") REFERENCES "phys_assets"("id"),
|
||||||
|
PRIMARY KEY("id")
|
||||||
);
|
);
|
||||||
CREATE TABLE "phys_assets" (
|
CREATE TABLE "phys_assets" (
|
||||||
"id" INTEGER NOT NULL,
|
"id" INTEGER NOT NULL,
|
||||||
"name" TEXT NOT NULL UNIQUE,
|
"name" TEXT NOT NULL UNIQUE,
|
||||||
"description" TEXT,
|
"description" TEXT,
|
||||||
"buy_transaction_id" INTEGER,
|
PRIMARY KEY("id")
|
||||||
"sell_transaction_id" INTEGER,
|
|
||||||
"is_expired" INTEGER NOT NULL DEFAULT 0,
|
|
||||||
FOREIGN KEY("sell_transaction_id") REFERENCES "fin_transactions"("id"),
|
|
||||||
PRIMARY KEY("id"),
|
|
||||||
FOREIGN KEY("buy_transaction_id") REFERENCES "fin_transactions"("id")
|
|
||||||
);
|
);
|
||||||
CREATE INDEX "i_balance_goals_asset_storage_id" ON "balance_goals" (
|
CREATE INDEX "i_balance_goals_asset_storage_id" ON "balance_goals" (
|
||||||
"asset_storage_id"
|
"asset_storage_id"
|
||||||
@ -116,6 +126,9 @@ CREATE INDEX "i_balances_asset_storage_id_date" ON "balances" (
|
|||||||
"asset_storage_id",
|
"asset_storage_id",
|
||||||
"date" DESC
|
"date" DESC
|
||||||
);
|
);
|
||||||
|
CREATE INDEX "i_fin_allocation_groups_end_date" ON "fin_allocation_groups" (
|
||||||
|
"end_date" DESC
|
||||||
|
);
|
||||||
CREATE INDEX "i_fin_asset_rates_asset_id_date" ON "fin_asset_rates" (
|
CREATE INDEX "i_fin_asset_rates_asset_id_date" ON "fin_asset_rates" (
|
||||||
"asset_id",
|
"asset_id",
|
||||||
"date" DESC
|
"date" DESC
|
||||||
@ -135,6 +148,9 @@ CREATE INDEX "i_fin_assets_storages_storage_id" ON "fin_assets_storages" (
|
|||||||
CREATE INDEX "i_fin_assets_type_id" ON "fin_assets" (
|
CREATE INDEX "i_fin_assets_type_id" ON "fin_assets" (
|
||||||
"type_id"
|
"type_id"
|
||||||
);
|
);
|
||||||
|
CREATE INDEX "i_fin_transaction_categories_parent_id" ON "fin_transaction_categories" (
|
||||||
|
"parent_id"
|
||||||
|
);
|
||||||
CREATE INDEX "i_fin_transactions_asset_storage_id_date" ON "fin_transactions" (
|
CREATE INDEX "i_fin_transactions_asset_storage_id_date" ON "fin_transactions" (
|
||||||
"asset_storage_id",
|
"asset_storage_id",
|
||||||
"date" DESC
|
"date" DESC
|
||||||
@ -145,11 +161,21 @@ CREATE INDEX "i_fin_transactions_category_id" ON "fin_transactions" (
|
|||||||
CREATE INDEX "i_fin_transactions_date" ON "fin_transactions" (
|
CREATE INDEX "i_fin_transactions_date" ON "fin_transactions" (
|
||||||
"date" DESC
|
"date" DESC
|
||||||
);
|
);
|
||||||
|
CREATE INDEX "i_fin_transactions_reason_phys_asset_ownership_id" ON "fin_transactions" (
|
||||||
|
"reason_phys_asset_ownership_id"
|
||||||
|
);
|
||||||
CREATE INDEX "i_fin_transactions_result_fin_asset_storage_id" ON "fin_transactions" (
|
CREATE INDEX "i_fin_transactions_result_fin_asset_storage_id" ON "fin_transactions" (
|
||||||
"reason_fin_asset_storage_id"
|
"reason_fin_asset_storage_id"
|
||||||
);
|
);
|
||||||
CREATE INDEX "i_fin_transactions_result_phys_asset_id" ON "balance_goals" (
|
CREATE INDEX "i_phys_asset_ownerships_asset_id_end_date" ON "phys_asset_ownerships" (
|
||||||
"result_transaction_id"
|
"asset_id",
|
||||||
|
"end_date" DESC
|
||||||
|
);
|
||||||
|
CREATE INDEX "i_phys_asset_ownerships_buy_fin_tx_id" ON "phys_asset_ownerships" (
|
||||||
|
"buy_fin_tx_id"
|
||||||
|
);
|
||||||
|
CREATE INDEX "i_phys_asset_ownerships_sell_fin_tx_id" ON "phys_asset_ownerships" (
|
||||||
|
"sell_fin_tx_id"
|
||||||
);
|
);
|
||||||
CREATE VIEW "current_balance_goals" AS select
|
CREATE VIEW "current_balance_goals" AS select
|
||||||
t.amount_left=0 as is_accomplished,
|
t.amount_left=0 as is_accomplished,
|
||||||
@ -258,8 +284,14 @@ from (
|
|||||||
left join fin_assets fa on fa.id=fas.asset_id
|
left join fin_assets fa on fa.id=fas.asset_id
|
||||||
left join fin_storages fs on fs.id=fas.storage_id
|
left join fin_storages fs on fs.id=fas.storage_id
|
||||||
where
|
where
|
||||||
|
(
|
||||||
|
date('now')>=fag.start_date and
|
||||||
|
(date('now')<=fag.end_date or fag.end_date is null)
|
||||||
|
) and
|
||||||
|
(
|
||||||
fas.id is null or
|
fas.id is null or
|
||||||
(fa.is_active and fs.is_active)
|
(fa.is_active and fs.is_active)
|
||||||
|
)
|
||||||
group by
|
group by
|
||||||
fag.id
|
fag.id
|
||||||
) t
|
) t
|
||||||
@ -468,7 +500,8 @@ from
|
|||||||
join fin_asset_types fat on fat.id=fa.type_id
|
join fin_asset_types fat on fat.id=fa.type_id
|
||||||
join fin_storages fs on fs.id=fas.storage_id
|
join fin_storages fs on fs.id=fas.storage_id
|
||||||
|
|
||||||
left join phys_assets r_pa on r_pa.id=ft.reason_phys_asset_id
|
left join phys_asset_ownerships r_pao on r_pao.id=ft.reason_phys_asset_ownership_id
|
||||||
|
left join phys_assets r_pa on r_pa.id=r_pao.asset_id
|
||||||
left join fin_assets_storages r_fas on r_fas.id=ft.reason_fin_asset_storage_id
|
left join fin_assets_storages r_fas on r_fas.id=ft.reason_fin_asset_storage_id
|
||||||
left join fin_assets r_fa on r_fa.id=r_fas.asset_id
|
left join fin_assets r_fa on r_fa.id=r_fas.asset_id
|
||||||
left join fin_asset_types r_fat on r_fat.id=r_fa.type_id
|
left join fin_asset_types r_fat on r_fat.id=r_fa.type_id
|
||||||
@ -588,28 +621,28 @@ begin
|
|||||||
end;
|
end;
|
||||||
CREATE TRIGGER fin_transaction_categories_insert insert on fin_transaction_categories
|
CREATE TRIGGER fin_transaction_categories_insert insert on fin_transaction_categories
|
||||||
begin
|
begin
|
||||||
with
|
with recursive
|
||||||
recursive parents(path, parent_id) as (
|
parents(parent_id) as (
|
||||||
values('/'||new.id||'/', new.parent_id)
|
values(new.parent_id)
|
||||||
union all
|
union
|
||||||
select
|
select
|
||||||
p.path||cat.id||'/', cat.parent_id
|
cat.parent_id
|
||||||
from
|
from
|
||||||
parents p
|
parents p
|
||||||
join fin_transaction_categories cat on cat.id=p.parent_id
|
join fin_transaction_categories cat on cat.id=p.parent_id
|
||||||
where
|
where
|
||||||
p.path not like '%/'||cat.id||'/%'
|
cat.id!=new.id
|
||||||
),
|
),
|
||||||
children(path, id) as (
|
children(id) as (
|
||||||
values('/'||new.id||'/', new.id)
|
values(new.id)
|
||||||
union all
|
union
|
||||||
select
|
select
|
||||||
c.path||cat.id||'/', cat.id
|
cat.id
|
||||||
from
|
from
|
||||||
children c
|
children c
|
||||||
join fin_transaction_categories cat on cat.parent_id=c.id
|
join fin_transaction_categories cat on cat.parent_id=c.id
|
||||||
where
|
where
|
||||||
c.path not like '%/'||cat.id||'/%'
|
cat.id!=new.id
|
||||||
)
|
)
|
||||||
select
|
select
|
||||||
case
|
case
|
||||||
@ -646,28 +679,28 @@ from
|
|||||||
end;
|
end;
|
||||||
CREATE TRIGGER fin_transaction_categories_update update of id,parent_id,is_passive,is_rebalance,is_initial_import on fin_transaction_categories
|
CREATE TRIGGER fin_transaction_categories_update update of id,parent_id,is_passive,is_rebalance,is_initial_import on fin_transaction_categories
|
||||||
begin
|
begin
|
||||||
with
|
with recursive
|
||||||
recursive parents(path, parent_id) as (
|
parents(parent_id) as (
|
||||||
values('/'||new.id||'/', new.parent_id)
|
values(new.parent_id)
|
||||||
union all
|
union
|
||||||
select
|
select
|
||||||
p.path||cat.id||'/', cat.parent_id
|
cat.parent_id
|
||||||
from
|
from
|
||||||
parents p
|
parents p
|
||||||
join fin_transaction_categories cat on cat.id=p.parent_id
|
join fin_transaction_categories cat on cat.id=p.parent_id
|
||||||
where
|
where
|
||||||
p.path not like '%/'||cat.id||'/%'
|
cat.id!=new.id
|
||||||
),
|
),
|
||||||
children(path, id) as (
|
children(id) as (
|
||||||
values('/'||new.id||'/', new.id)
|
values(new.id)
|
||||||
union all
|
union
|
||||||
select
|
select
|
||||||
c.path||cat.id||'/', cat.id
|
cat.id
|
||||||
from
|
from
|
||||||
children c
|
children c
|
||||||
join fin_transaction_categories cat on cat.parent_id=c.id
|
join fin_transaction_categories cat on cat.parent_id=c.id
|
||||||
where
|
where
|
||||||
c.path not like '%/'||cat.id||'/%'
|
cat.id!=new.id
|
||||||
)
|
)
|
||||||
select
|
select
|
||||||
case
|
case
|
||||||
@ -720,7 +753,7 @@ begin
|
|||||||
)
|
)
|
||||||
on conflict do nothing;
|
on conflict do nothing;
|
||||||
|
|
||||||
insert into fin_transactions(date, asset_storage_id, amount, category_id, reason_fin_asset_storage_id, reason_phys_asset_id)
|
insert into fin_transactions(date, asset_storage_id, amount, category_id, reason_fin_asset_storage_id, reason_phys_asset_ownership_id)
|
||||||
values(
|
values(
|
||||||
coalesce(new.date, date('now')),
|
coalesce(new.date, date('now')),
|
||||||
(
|
(
|
||||||
@ -751,7 +784,19 @@ begin
|
|||||||
fat.name = new.reason_fin_asset_type and
|
fat.name = new.reason_fin_asset_type and
|
||||||
fs.name = new.reason_fin_asset_storage
|
fs.name = new.reason_fin_asset_storage
|
||||||
),
|
),
|
||||||
(select id from phys_assets where name=new.reason_phys_asset)
|
(
|
||||||
|
select
|
||||||
|
pao.id
|
||||||
|
from
|
||||||
|
phys_assets pa
|
||||||
|
join phys_asset_ownerships pao on pao.asset_id=pa.id
|
||||||
|
where
|
||||||
|
pa.name=new.reason_phys_asset and
|
||||||
|
(
|
||||||
|
coalesce(new.date, date('now'))>=pao.start_date and
|
||||||
|
(coalesce(new.date, date('now'))<=pao.end_date or pao.end_date is null)
|
||||||
|
)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
select
|
select
|
||||||
@ -822,7 +867,19 @@ begin
|
|||||||
fat.name = new.reason_fin_asset_type and
|
fat.name = new.reason_fin_asset_type and
|
||||||
fs.name = new.reason_fin_asset_storage
|
fs.name = new.reason_fin_asset_storage
|
||||||
),
|
),
|
||||||
reason_phys_asset_id = (select id from phys_assets where name=new.reason_phys_asset)
|
reason_phys_asset_ownership_id = (
|
||||||
|
select
|
||||||
|
pao.id
|
||||||
|
from
|
||||||
|
phys_assets pa
|
||||||
|
join phys_asset_ownerships pao on pao.asset_id=pa.id
|
||||||
|
where
|
||||||
|
pa.name=new.reason_phys_asset and
|
||||||
|
(
|
||||||
|
coalesce(new.date, date('now'))>=pao.start_date and
|
||||||
|
(coalesce(new.date, date('now'))<=pao.end_date or pao.end_date is null)
|
||||||
|
)
|
||||||
|
)
|
||||||
where
|
where
|
||||||
id=new.pseudo_id;
|
id=new.pseudo_id;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user