]> git.ktnx.net Git - mobile-ledger.git/blob - app/src/main/res/raw/create_db.sql
describe options 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(profile varchar not null, account varchar not null, currency varchar not null default '', value decimal not null, generation integer default 0 );
43 create unique index un_account_values on account_values(profile,account,currency);
44 create table description_history(description varchar not null primary key, description_upper varchar, generation integer default 0);
45 create unique index un_description_history on description_history(description_upper);
46 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);
47 create unique index un_transactions_id on transactions(profile,id);
48 create unique index un_transactions_data_hash on transactions(profile,data_hash);
49 create index idx_transaction_description on transactions(description);
50 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));
51 create unique index un_transaction_accounts_order on transaction_accounts(profile, transaction_id, order_no);
52 create table currencies(id integer not null primary key, name varchar not null, position varchar not null, has_gap integer not null);
53
54 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);
55 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);
56 create index fk_template_accounts_template on template_accounts(template_id);
57 create index fk_template_accounts_currency on template_accounts(currency);
58
59 COMMIT TRANSACTION;
60 -- updated to revision 58