Sobes.tech
Назад к вопросам
Middle+
1

Смоделировать простую банковскую систему: - Таблица `accounts`: - `id`, - `owner_id`, - `currency`, - `created_at`. - Таблица `transactions`: - `id`, - `account_id`, - `amount`, - `created_at`. **Требования:** 1. Написать SQL для создания схемы с нужными ограничениями (NOT NULL, FK, CHECK на ненулевой `amount`). 2. Написать запрос: - получить текущий баланс счёта по `account_id` (сумма amount). 3. Усложнение: поддержать дебет/кредит (двойная запись). Cleanup

Компании, где спрашивали
101ХР101ХР

Ответ от нейросети

sobes.tech AI

sql -- 1. Создание схемы с ограничениями CREATE TABLE accounts ( id SERIAL PRIMARY KEY, owner_id INT NOT NULL, currency VARCHAR(3) NOT NULL, created_at TIMESTAMP NOT NULL DEFAULT NOW() );

CREATE TABLE transactions ( id SERIAL PRIMARY KEY, account_id INT NOT NULL REFERENCES accounts(id) ON DELETE CASCADE, amount NUMERIC NOT NULL CHECK (amount <> 0), created_at TIMESTAMP NOT NULL DEFAULT NOW() );

-- 2. Запрос для получения текущего баланса по account_id SELECT account_id, SUM(amount) AS balance FROM transactions WHERE account_id = $1 GROUP BY account_id;

-- 3. Усложнение: поддержка дебет/кредит (двойная запись) -- Для двойной записи добавим таблицу ledger_entries CREATE TABLE ledger_entries ( id SERIAL PRIMARY KEY, transaction_id INT NOT NULL REFERENCES transactions(id) ON DELETE CASCADE, account_id INT NOT NULL REFERENCES accounts(id), amount NUMERIC NOT NULL CHECK (amount <> 0), created_at TIMESTAMP NOT NULL DEFAULT NOW() );

-- В этом случае каждая транзакция будет иметь две записи в ledger_entries: -- дебет (откуда списывается) с отрицательным amount -- кредит (куда зачисляется) с положительным amount

-- Запрос баланса по account_id с учетом ledger_entries SELECT account_id, SUM(amount) AS balance FROM ledger_entries WHERE account_id = $1 GROUP BY account_id;