Add K8s deployment files, restructure to backend/frontend

This commit is contained in:
Agent
2026-03-20 05:12:22 +00:00
parent cea86e48a7
commit f70ba958c7
8 changed files with 371 additions and 0 deletions

View File

@@ -0,0 +1,98 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: todo-init-sql
data:
init.sql: |
-- 初始化数据库脚本
-- 此文件会在 PostgreSQL 首次启动时自动执行
CREATE TABLE IF NOT EXISTS "user" (
id VARCHAR(36) PRIMARY KEY,
username VARCHAR(50) NOT NULL UNIQUE,
password VARCHAR(255) NOT NULL,
real_name VARCHAR(100),
phone VARCHAR(20),
role VARCHAR(20) DEFAULT 'sales',
status INTEGER DEFAULT 1,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS category (
id VARCHAR(36) PRIMARY KEY,
name VARCHAR(100) NOT NULL,
parent_id VARCHAR(36),
sort_order INTEGER DEFAULT 0,
status INTEGER DEFAULT 1,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS product (
id VARCHAR(36) PRIMARY KEY,
name VARCHAR(200) NOT NULL,
category_id VARCHAR(36),
unit VARCHAR(20),
price DECIMAL(10,2),
stock_quantity INTEGER DEFAULT 0,
status INTEGER DEFAULT 1,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS customer (
id VARCHAR(36) PRIMARY KEY,
name VARCHAR(200) NOT NULL,
phone VARCHAR(20),
address VARCHAR(500),
contact_person VARCHAR(100),
remark TEXT,
status INTEGER DEFAULT 1,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS "order" (
id VARCHAR(36) PRIMARY KEY,
order_no VARCHAR(50) NOT NULL UNIQUE,
customer_id VARCHAR(36),
sales_user_id VARCHAR(36),
total_amount DECIMAL(10,2) DEFAULT 0,
status VARCHAR(20) DEFAULT 'pending',
remark TEXT,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS order_item (
id VARCHAR(36) PRIMARY KEY,
order_id VARCHAR(36) NOT NULL,
product_id VARCHAR(36) NOT NULL,
quantity INTEGER NOT NULL,
unit_price DECIMAL(10,2) NOT NULL,
subtotal DECIMAL(10,2) NOT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS stock (
id VARCHAR(36) PRIMARY KEY,
product_id VARCHAR(36) NOT NULL,
warehouse VARCHAR(100),
quantity INTEGER DEFAULT 0,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE TABLE IF NOT EXISTS stock_flow (
id VARCHAR(36) PRIMARY KEY,
product_id VARCHAR(36) NOT NULL,
type VARCHAR(20) NOT NULL,
quantity INTEGER NOT NULL,
remark VARCHAR(500),
operator_id VARCHAR(36),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
-- 插入默认管理员
INSERT INTO "user" (id, username, password, real_name, role)
VALUES ('admin', 'admin', '$2a$10$N.zmdr9k7uOCQb376NoUnuTJ8iAt6Z5EHsM8lE9lBOsl7iAt6Z5EH', '管理员', 'admin')
ON CONFLICT (username) DO NOTHING;