wiki:ddlScript.sql

Version 3 (modified by 211101, 4 weeks ago) ( diff )

--

-- Delete tables if they exist
DROP TABLE IF EXISTS transaction_breakdown CASCADE;
DROP TABLE IF EXISTS transaction CASCADE;
DROP TABLE IF EXISTS transaction_account CASCADE;
DROP TABLE IF EXISTS tag CASCADE;
DROP TABLE IF EXISTS "user" CASCADE;
DROP TABLE IF EXISTS tag_assigned_to_transaction CASCADE;

-- Create USER table
CREATE TABLE "user" (
    user_id SERIAL PRIMARY KEY,
    user_name VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL,
    password VARCHAR(100) NOT NULL
);

-- Create TRANSACTION_ACCOUNT table
CREATE TABLE transaction_account (
    transaction_account_id SERIAL PRIMARY KEY,
    account_name VARCHAR(50),
    balance DECIMAL(10, 2),
    user_id INT REFERENCES "user"(user_id)
);

-- Create TRANSACTION table
CREATE TABLE transaction (
    transaction_id SERIAL PRIMARY KEY,
    transaction_name VARCHAR(100),
    amount DECIMAL(10, 2) NOT NULL,
    net_amount DECIMAL(10, 2),
    date TIMESTAMPTZ NOT NULL
);

-- Create TAG table
CREATE TABLE tag (
    tag_id SERIAL PRIMARY KEY,
    tag_name VARCHAR(50) NOT NULL
);

-- Create TAG_ASSIGNED_TO_TRANSACTION table
CREATE TABLE tag_assigned_to_transaction (
    tag_assigned_to_transaction_id SERIAL PRIMARY KEY,
    transaction_id INT NOT NULL REFERENCES transaction(transaction_id) ON DELETE CASCADE,
    tag_id INT NOT NULL REFERENCES tag(tag_id) ON DELETE CASCADE
);

-- Create TRANSACTION_BREAKDOWN table
CREATE TABLE transaction_breakdown (
    transaction_breakdown_id SERIAL PRIMARY KEY,
    transaction_id INT REFERENCES transaction(transaction_id),
    transaction_account_id INT REFERENCES transaction_account(transaction_account_id),
    spent_amount DECIMAL(10, 2),
    earned_amount DECIMAL(10, 2)
);
Note: See TracWiki for help on using the wiki.