summaryrefslogtreecommitdiff
path: root/init.sql
blob: a02895afd192768976f8ee648f30062daa48ae33 (plain)
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
CREATE TABLE clients (
  id SERIAL PRIMARY KEY,
  name VARCHAR(50) NOT NULL,
  mov_limit INTEGER NOT NULL
);

CREATE TYPE transaction_type AS ENUM ('credit', 'debit');

CREATE TABLE transactions (
  id SERIAL PRIMARY KEY,
  client_id INTEGER REFERENCES clients,
  value INTEGER NOT NULL,
  type transaction_type NOT NULL,
  description VARCHAR(10) NOT NULL,
  created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
);

CREATE INDEX idx_client_id_transactions ON transactions (client_id);

CREATE TABLE balances (
  id SERIAL PRIMARY KEY,
  client_id INTEGER REFERENCES clients,
  value INTEGER NOT NULL
);

CREATE INDEX idx_client_id_balances ON balances (client_id);

DO $$
BEGIN
  INSERT INTO clients (name, mov_limit)
  VALUES
      ('naruto', 100000),
      ('mob', 80000),
      ('jojo', 1000000),
      ('hellboy', 10000000),
      ('ultramega', 500000);
  INSERT INTO balances (client_id, value)
      SELECT id, 0 FROM clients;
END;
$$