]> git.ktnx.net Git - mobile-ledger.git/blob - app/src/main/res/raw/create_db.sql
describe description_history to Room
[mobile-ledger.git] / app / src / main / res / raw / create_db.sql
1 -- Copyright © 2021 Damyan Ivanov.
2 -- This file is part of MoLe.
3 -- MoLe is free software: you can distribute it and/or modify it
4 -- under the term of the GNU General Public License as published by
5 -- the Free Software Foundation, either version 3 of the License, or
6 -- (at your opinion), any later version.
7 --
8 -- MoLe is distributed in the hope that it will be useful,
9 -- but WITHOUT ANY WARRANTY; without even the implied warranty of
10 -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 -- GNU General Public License terms for details.
12 --
13 -- You should have received a copy of the GNU General Public License
14 -- along with MoLe. If not, see <https://www.gnu.org/licenses/>.
15
16 BEGIN TRANSACTION;
17
18 create table profiles(
19  uuid text not null,
20  name text not null,
21  url text not null,
22  use_authentication integer not null,
23  auth_user text,
24  auth_password text,
25  order_no integer not null,
26  permit_posting integer not null default 0,
27  theme integer not null default -1,
28  preferred_accounts_filter varchar,
29  future_dates integer not null,
30  api_version integer not null,
31  show_commodity_by_default integer not null default 0,
32  default_commodity text,
33  show_comments_by_default integer not null default 1,
34  detected_version_pre_1_19 integer not null,
35  detected_version_major integer not null,
36  detected_version_minor integer not null,
37  primary key(uuid));
38
39 create table accounts(profile varchar not null, name varchar not null, name_upper varchar not null, level integer not null, parent_name varchar, expanded integer not null default 1, amounts_expanded integer not null default 0, generation integer not null default 0, primary key(profile, name));
40 create table options(profile varchar not null, name varchar not null, value varchar, primary key(profile, name));
41
42 create table account_values(
43  profile varchar not null,
44  account varchar not null,
45  currency varchar not null default '',
46  value real not null,
47  generation integer not null default 0,
48  primary key(profile, account, currency));
49
50 create table description_history(description varchar collate NOCASE not null,
51  description_upper varchar not null,
52  generation integer not null default 0,
53  primary key(description));
54
55 create table transactions(profile varchar not null, id integer not null, data_hash varchar not null, year integer not null, month integer not null, day integer not null, description varchar not null, comment varchar, generation integer default 0);
56 create unique index un_transactions_id on transactions(profile,id);
57 create unique index un_transactions_data_hash on transactions(profile,data_hash);
58 create index idx_transaction_description on transactions(description);
59 create table transaction_accounts(profile varchar not null, transaction_id integer not null, order_no integer not null, account_name varchar not null, currency varchar not null default '', amount decimal not null, comment varchar, generation integer default 0, constraint fk_transaction_accounts_acc foreign key(profile,account_name) references accounts(profile,name), constraint fk_transaction_accounts_trn foreign key(profile, transaction_id) references transactions(profile,id));
60 create unique index un_transaction_accounts_order on transaction_accounts(profile, transaction_id, order_no);
61 create table currencies(id integer not null primary key, name varchar not null, position varchar not null, has_gap integer not null);
62
63 CREATE TABLE templates (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name TEXT NOT NULL, regular_expression TEXT NOT NULL, test_text TEXT, transaction_description TEXT, transaction_description_match_group INTEGER, transaction_comment TEXT, transaction_comment_match_group INTEGER, date_year INTEGER, date_year_match_group INTEGER, date_month INTEGER, date_month_match_group INTEGER, date_day INTEGER, date_day_match_group INTEGER, is_fallback INTEGER NOT NULL DEFAULT 0);
64 CREATE TABLE template_accounts(id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, template_id INTEGER NOT NULL, acc TEXT, position INTEGER NOT NULL, acc_match_group INTEGER, currency INTEGER, currency_match_group INTEGER, amount REAL, amount_match_group INTEGER, comment TEXT, comment_match_group INTEGER, negate_amount INTEGER, FOREIGN KEY(template_id) REFERENCES templates(id) ON UPDATE RESTRICT ON DELETE CASCADE, FOREIGN KEY(currency) REFERENCES currencies(id) ON UPDATE RESTRICT ON DELETE RESTRICT);
65 create index fk_template_accounts_template on template_accounts(template_id);
66 create index fk_template_accounts_currency on template_accounts(currency);
67
68 COMMIT TRANSACTION;
69 -- updated to revision 58