-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdatabase_structure.sql
112 lines (102 loc) · 3 KB
/
database_structure.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
CREATE TABLE IF NOT EXISTS User_Table(
user_id INTEGER PRIMARY KEY AUTOINCREMENT,
session_id TEXT,
highest_lifetime_balance FLOAT,
highest_transaction_id BIGINT,
highest_category_id BIGINT,
highest_category_rule_id BIGINT,
highest_saving_goal_id BIGINT,
highest_payment_request_id BIGINT,
highest_user_message_id BIGINT,
highest_message_rule_id BIGINT
);
CREATE TABLE IF NOT EXISTS Transaction_Table(
user_id INTEGER,
transaction_id BIGINT,
date DATETIME,
amount FLOAT,
description TEXT,
external_iban TEXT,
type TEXT,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
PRIMARY KEY(user_id, transaction_id)
);
CREATE TABLE IF NOT EXISTS Category_Table(
user_id INTEGER,
category_id BIGINT,
name TEXT,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
PRIMARY KEY(user_id, category_id)
);
CREATE TABLE IF NOT EXISTS Transaction_Category(
user_id INTEGER,
transaction_id BIGINT,
category_id BIGINT,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
FOREIGN KEY(transaction_id) REFERENCES Transaction_Table(transaction_id),
FOREIGN KEY(category_id) REFERENCES Category_Table(category_id),
PRIMARY KEY(user_id, transaction_id, category_id)
);
CREATE TABLE IF NOT EXISTS Category_Rule(
user_id INTEGER,
category_rule_id BIGINT,
description TEXT,
external_iban TEXT,
type TEXT,
category_id BIGINT,
apply_on_history BOOLEAN,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
FOREIGN KEY(category_id) REFERENCES Category_Table(category_id),
PRIMARY KEY(user_id, category_rule_id)
);
CREATE TABLE IF NOT EXISTS Saving_Goal(
user_id INTEGER,
saving_goal_id BIGINT,
creation_date DATETIME,
deletion_date DATETIME,
name TEXT,
goal FLOAT,
save_per_month FLOAT,
min_balance_required FLOAT,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
PRIMARY KEY(user_id, saving_goal_id)
);
CREATE TABLE IF NOT EXISTS Payment_Request(
user_id INTEGER,
payment_request_id BIGINT,
description TEXT,
due_date DATETIME,
amount FLOAT,
number_of_requests BIGINT,
filled BOOLEAN,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
PRIMARY KEY(user_id, payment_request_id)
);
CREATE TABLE IF NOT EXISTS Payment_Request_Transaction(
user_id INTEGER,
payment_request_id BIGINT,
transaction_id BIGINT,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
FOREIGN KEY(payment_request_id) REFERENCES Payment_Request(payment_request_id),
FOREIGN KEY(transaction_id) REFERENCES Transaction_Table(transaction_id),
PRIMARY KEY(user_id, payment_request_id, transaction_id)
);
CREATE TABLE IF NOT EXISTS User_Message(
user_id INTEGER,
user_message_id BIGINT,
message TEXT,
date DATETIME,
read BOOLEAN,
type TEXT,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
PRIMARY KEY(user_id, user_message_id)
);
CREATE TABLE IF NOT EXISTS Message_Rule(
user_id INTEGER,
message_rule_id BIGINT,
category_id BIGINT,
type TEXT,
value float,
FOREIGN KEY(user_id) REFERENCES User_Table(user_id),
PRIMARY KEY(user_id, message_rule_id)
);