253 lines
7.8 KiB
MySQL
253 lines
7.8 KiB
MySQL
![]() |
-- 订单管理系统数据库初始化脚本
|
|||
|
-- 在Supabase SQL编辑器中运行此脚本
|
|||
|
|
|||
|
-- 创建订单表(如果不存在)
|
|||
|
CREATE TABLE IF NOT EXISTS orders (
|
|||
|
id UUID DEFAULT gen_random_uuid() PRIMARY KEY,
|
|||
|
user_id TEXT NOT NULL,
|
|||
|
interpreter_id UUID NULL,
|
|||
|
type TEXT NOT NULL CHECK (type IN ('interpretation', 'document', 'video', 'localization')),
|
|||
|
status TEXT NOT NULL DEFAULT 'pending' CHECK (status IN ('pending', 'confirmed', 'in_progress', 'completed', 'cancelled')),
|
|||
|
source_language TEXT NOT NULL,
|
|||
|
target_language TEXT NOT NULL,
|
|||
|
scheduled_date TIMESTAMP WITH TIME ZONE NOT NULL,
|
|||
|
duration INTEGER NULL, -- 持续时间(分钟)
|
|||
|
service_address TEXT NULL,
|
|||
|
special_requirements TEXT NULL,
|
|||
|
total_amount DECIMAL(10,2) NOT NULL DEFAULT 0.00,
|
|||
|
payment_status TEXT NOT NULL DEFAULT 'pending' CHECK (payment_status IN ('pending', 'paid', 'refunded')),
|
|||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
|||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
|
|||
|
);
|
|||
|
|
|||
|
-- 创建用户表(如果不存在)
|
|||
|
CREATE TABLE IF NOT EXISTS users (
|
|||
|
id UUID DEFAULT gen_random_uuid() PRIMARY KEY,
|
|||
|
name TEXT NOT NULL,
|
|||
|
email TEXT UNIQUE NOT NULL,
|
|||
|
phone TEXT NULL,
|
|||
|
company TEXT NULL,
|
|||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
|||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
|
|||
|
);
|
|||
|
|
|||
|
-- 创建口译员表(如果不存在)
|
|||
|
CREATE TABLE IF NOT EXISTS interpreters (
|
|||
|
id UUID DEFAULT gen_random_uuid() PRIMARY KEY,
|
|||
|
name TEXT NOT NULL,
|
|||
|
email TEXT UNIQUE NOT NULL,
|
|||
|
phone TEXT NULL,
|
|||
|
languages TEXT[] NOT NULL DEFAULT '{}',
|
|||
|
specializations TEXT[] NOT NULL DEFAULT '{}',
|
|||
|
hourly_rate DECIMAL(10,2) NOT NULL DEFAULT 0.00,
|
|||
|
status TEXT NOT NULL DEFAULT 'active' CHECK (status IN ('active', 'inactive', 'busy')),
|
|||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
|||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
|
|||
|
);
|
|||
|
|
|||
|
-- 创建服务费率表
|
|||
|
CREATE TABLE IF NOT EXISTS service_rates (
|
|||
|
id UUID DEFAULT gen_random_uuid() PRIMARY KEY,
|
|||
|
service_type TEXT NOT NULL,
|
|||
|
language_pair TEXT NOT NULL,
|
|||
|
base_rate DECIMAL(10,2) NOT NULL DEFAULT 0.00,
|
|||
|
urgency_multiplier DECIMAL(3,2) NOT NULL DEFAULT 1.00,
|
|||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
|||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
|||
|
UNIQUE(service_type, language_pair)
|
|||
|
);
|
|||
|
|
|||
|
-- 插入测试用户数据
|
|||
|
INSERT INTO users (id, name, email, phone, company) VALUES
|
|||
|
('user_001', '张三', 'zhangsan@example.com', '13800138001', '北京科技有限公司'),
|
|||
|
('user_002', '李四', 'lisi@example.com', '13800138002', '上海贸易集团'),
|
|||
|
('user_003', '王五', 'wangwu@example.com', '13800138003', '深圳创新科技'),
|
|||
|
('user_004', '赵六', 'zhaoliu@example.com', '13800138004', '广州国际贸易'),
|
|||
|
('user_005', '孙七', 'sunqi@example.com', '13800138005', '杭州电子商务')
|
|||
|
ON CONFLICT (email) DO NOTHING;
|
|||
|
|
|||
|
-- 插入测试口译员数据
|
|||
|
INSERT INTO interpreters (id, name, email, phone, languages, specializations, hourly_rate) VALUES
|
|||
|
('int_001', '王译员', 'wang@interpreter.com', '13900139001', ARRAY['zh', 'en'], ARRAY['business', 'technology'], 150.00),
|
|||
|
('int_002', '陈译员', 'chen@interpreter.com', '13900139002', ARRAY['en', 'zh'], ARRAY['legal', 'medical'], 180.00),
|
|||
|
('int_003', '刘译员', 'liu@interpreter.com', '13900139003', ARRAY['zh', 'ja'], ARRAY['business', 'tourism'], 120.00)
|
|||
|
ON CONFLICT (email) DO NOTHING;
|
|||
|
|
|||
|
-- 插入服务费率数据
|
|||
|
INSERT INTO service_rates (service_type, language_pair, base_rate, urgency_multiplier) VALUES
|
|||
|
('interpretation', 'zh-en', 120.00, 1.5),
|
|||
|
('interpretation', 'en-zh', 120.00, 1.5),
|
|||
|
('document', 'zh-en', 0.15, 2.0),
|
|||
|
('document', 'en-zh', 0.15, 2.0),
|
|||
|
('video', 'zh-en', 200.00, 1.8),
|
|||
|
('video', 'en-zh', 200.00, 1.8),
|
|||
|
('localization', 'zh-ja', 0.20, 1.2),
|
|||
|
('localization', 'ja-zh', 0.20, 1.2)
|
|||
|
ON CONFLICT (service_type, language_pair) DO NOTHING;
|
|||
|
|
|||
|
-- 插入测试订单数据
|
|||
|
INSERT INTO orders (
|
|||
|
user_id,
|
|||
|
interpreter_id,
|
|||
|
type,
|
|||
|
status,
|
|||
|
source_language,
|
|||
|
target_language,
|
|||
|
scheduled_date,
|
|||
|
duration,
|
|||
|
service_address,
|
|||
|
special_requirements,
|
|||
|
total_amount,
|
|||
|
payment_status,
|
|||
|
created_at,
|
|||
|
updated_at
|
|||
|
) VALUES
|
|||
|
(
|
|||
|
'user_001',
|
|||
|
NULL,
|
|||
|
'interpretation',
|
|||
|
'pending',
|
|||
|
'zh',
|
|||
|
'en',
|
|||
|
'2024-12-05 14:00:00+08',
|
|||
|
120,
|
|||
|
'北京市朝阳区商务中心',
|
|||
|
'商务会议同声传译,需要专业商务背景',
|
|||
|
800.00,
|
|||
|
'pending',
|
|||
|
NOW() - INTERVAL '1 day',
|
|||
|
NOW() - INTERVAL '1 day'
|
|||
|
),
|
|||
|
(
|
|||
|
'user_002',
|
|||
|
'int_001',
|
|||
|
'document',
|
|||
|
'completed',
|
|||
|
'zh',
|
|||
|
'en',
|
|||
|
'2024-11-28 09:00:00+08',
|
|||
|
480,
|
|||
|
'上海市浦东新区办公楼',
|
|||
|
'技术文档翻译,软件相关',
|
|||
|
1200.00,
|
|||
|
'paid',
|
|||
|
NOW() - INTERVAL '5 days',
|
|||
|
NOW() - INTERVAL '2 days'
|
|||
|
),
|
|||
|
(
|
|||
|
'user_003',
|
|||
|
'int_002',
|
|||
|
'video',
|
|||
|
'in_progress',
|
|||
|
'en',
|
|||
|
'zh',
|
|||
|
'2024-12-01 15:30:00+08',
|
|||
|
90,
|
|||
|
'线上视频会议',
|
|||
|
'国际视频会议翻译,紧急项目',
|
|||
|
720.00,
|
|||
|
'pending',
|
|||
|
NOW() - INTERVAL '2 hours',
|
|||
|
NOW() - INTERVAL '1 hour'
|
|||
|
),
|
|||
|
(
|
|||
|
'user_004',
|
|||
|
'int_003',
|
|||
|
'document',
|
|||
|
'confirmed',
|
|||
|
'zh',
|
|||
|
'en',
|
|||
|
'2024-12-03 10:00:00+08',
|
|||
|
240,
|
|||
|
'广州市天河区律师事务所',
|
|||
|
'商务合同翻译,需要法律专业背景',
|
|||
|
600.00,
|
|||
|
'pending',
|
|||
|
NOW() - INTERVAL '2 days',
|
|||
|
NOW() - INTERVAL '6 hours'
|
|||
|
),
|
|||
|
(
|
|||
|
'user_005',
|
|||
|
NULL,
|
|||
|
'localization',
|
|||
|
'cancelled',
|
|||
|
'zh',
|
|||
|
'ja',
|
|||
|
'2024-12-02 09:00:00+08',
|
|||
|
360,
|
|||
|
'杭州市西湖区科技园',
|
|||
|
'产品说明书多语言翻译',
|
|||
|
900.00,
|
|||
|
'refunded',
|
|||
|
NOW() - INTERVAL '3 days',
|
|||
|
NOW() - INTERVAL '2 days'
|
|||
|
)
|
|||
|
ON CONFLICT DO NOTHING;
|
|||
|
|
|||
|
-- 创建更新时间戳的触发器函数
|
|||
|
CREATE OR REPLACE FUNCTION update_updated_at_column()
|
|||
|
RETURNS TRIGGER AS $$
|
|||
|
BEGIN
|
|||
|
NEW.updated_at = NOW();
|
|||
|
RETURN NEW;
|
|||
|
END;
|
|||
|
$$ language 'plpgsql';
|
|||
|
|
|||
|
-- 为各表创建更新时间戳触发器
|
|||
|
DROP TRIGGER IF EXISTS update_orders_updated_at ON orders;
|
|||
|
CREATE TRIGGER update_orders_updated_at
|
|||
|
BEFORE UPDATE ON orders
|
|||
|
FOR EACH ROW
|
|||
|
EXECUTE FUNCTION update_updated_at_column();
|
|||
|
|
|||
|
DROP TRIGGER IF EXISTS update_users_updated_at ON users;
|
|||
|
CREATE TRIGGER update_users_updated_at
|
|||
|
BEFORE UPDATE ON users
|
|||
|
FOR EACH ROW
|
|||
|
EXECUTE FUNCTION update_updated_at_column();
|
|||
|
|
|||
|
DROP TRIGGER IF EXISTS update_interpreters_updated_at ON interpreters;
|
|||
|
CREATE TRIGGER update_interpreters_updated_at
|
|||
|
BEFORE UPDATE ON interpreters
|
|||
|
FOR EACH ROW
|
|||
|
EXECUTE FUNCTION update_updated_at_column();
|
|||
|
|
|||
|
-- 启用行级安全策略(RLS)
|
|||
|
ALTER TABLE orders ENABLE ROW LEVEL SECURITY;
|
|||
|
ALTER TABLE users ENABLE ROW LEVEL SECURITY;
|
|||
|
ALTER TABLE interpreters ENABLE ROW LEVEL SECURITY;
|
|||
|
ALTER TABLE service_rates ENABLE ROW LEVEL SECURITY;
|
|||
|
|
|||
|
-- 创建基本的RLS策略(允许所有操作,实际使用时需要根据需求调整)
|
|||
|
CREATE POLICY "Allow all operations on orders" ON orders FOR ALL USING (true);
|
|||
|
CREATE POLICY "Allow all operations on users" ON users FOR ALL USING (true);
|
|||
|
CREATE POLICY "Allow all operations on interpreters" ON interpreters FOR ALL USING (true);
|
|||
|
CREATE POLICY "Allow all operations on service_rates" ON service_rates FOR ALL USING (true);
|
|||
|
|
|||
|
-- 创建索引以提高查询性能
|
|||
|
CREATE INDEX IF NOT EXISTS idx_orders_user_id ON orders(user_id);
|
|||
|
CREATE INDEX IF NOT EXISTS idx_orders_interpreter_id ON orders(interpreter_id);
|
|||
|
CREATE INDEX IF NOT EXISTS idx_orders_status ON orders(status);
|
|||
|
CREATE INDEX IF NOT EXISTS idx_orders_scheduled_date ON orders(scheduled_date);
|
|||
|
CREATE INDEX IF NOT EXISTS idx_orders_created_at ON orders(created_at);
|
|||
|
|
|||
|
-- 查询验证数据插入
|
|||
|
SELECT
|
|||
|
'orders' as table_name,
|
|||
|
COUNT(*) as record_count
|
|||
|
FROM orders
|
|||
|
UNION ALL
|
|||
|
SELECT
|
|||
|
'users' as table_name,
|
|||
|
COUNT(*) as record_count
|
|||
|
FROM users
|
|||
|
UNION ALL
|
|||
|
SELECT
|
|||
|
'interpreters' as table_name,
|
|||
|
COUNT(*) as record_count
|
|||
|
FROM interpreters
|
|||
|
UNION ALL
|
|||
|
SELECT
|
|||
|
'service_rates' as table_name,
|
|||
|
COUNT(*) as record_count
|
|||
|
FROM service_rates;
|