230 lines
14 KiB
SQL
230 lines
14 KiB
SQL
-- =========================
|
||
-- model_gateway_models
|
||
-- =========================
|
||
CREATE TABLE IF NOT EXISTS model_gateway_models (
|
||
id int8 PRIMARY KEY,
|
||
tenant_id int8 NOT NULL DEFAULT 0,
|
||
creator varchar(64) NOT NULL,
|
||
created_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updater varchar(64) NOT NULL,
|
||
updated_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
deleted_at timestamp(6),
|
||
model_name varchar(128) NOT NULL,
|
||
model_type int2 NOT NULL DEFAULT 0,
|
||
operator_name varchar(64) NOT NULL DEFAULT '',
|
||
base_url varchar(256) NOT NULL,
|
||
http_method varchar(8) NOT NULL DEFAULT 'POST',
|
||
head_msg jsonb NOT NULL DEFAULT '{}',
|
||
api_key varchar(256) NOT NULL DEFAULT '',
|
||
is_private int2 NOT NULL DEFAULT 0,
|
||
enabled int2 NOT NULL DEFAULT 1,
|
||
is_chat_model int2 NOT NULL DEFAULT 0,
|
||
is_owner int2 NOT NULL DEFAULT 99,
|
||
form_json jsonb NOT NULL DEFAULT '{}',
|
||
request_mapping jsonb NOT NULL DEFAULT '{}',
|
||
response_mapping jsonb NOT NULL DEFAULT '{}',
|
||
response_body varchar(128) NOT NULL DEFAULT '',
|
||
token_config jsonb NOT NULL DEFAULT '{}',
|
||
extend_mapping jsonb NOT NULL DEFAULT '{}',
|
||
query_config jsonb NOT NULL DEFAULT '{}',
|
||
stream_config jsonb NOT NULL DEFAULT '{}',
|
||
first_frame varchar(128) NOT NULL DEFAULT '',
|
||
last_frame varchar(128) NOT NULL DEFAULT '',
|
||
max_concurrency int4 NOT NULL DEFAULT 10,
|
||
timeout_seconds int4 NOT NULL DEFAULT 600,
|
||
retry_times int2 NOT NULL DEFAULT 3,
|
||
response_token_field varchar(128) NOT NULL DEFAULT '',
|
||
call_mode int2 NOT NULL DEFAULT 0,
|
||
required_fields jsonb NOT NULL DEFAULT '[]',
|
||
max_tokens int4 DEFAULT 0
|
||
);
|
||
|
||
CREATE UNIQUE INDEX IF NOT EXISTS uk_model_gateway_models_tenant_creator_model ON model_gateway_models (tenant_id, creator, model_name);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_models_model_name ON model_gateway_models (model_name);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_models_model_type ON model_gateway_models (model_type);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_models_tenant_id ON model_gateway_models (tenant_id);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_models_deleted_at ON model_gateway_models (deleted_at);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_models_enabled ON model_gateway_models (enabled);
|
||
|
||
COMMENT ON TABLE model_gateway_models IS '模型配置表';
|
||
COMMENT ON COLUMN model_gateway_models.id IS '主键ID(非自增)';
|
||
COMMENT ON COLUMN model_gateway_models.tenant_id IS '租户ID';
|
||
COMMENT ON COLUMN model_gateway_models.creator IS '创建人';
|
||
COMMENT ON COLUMN model_gateway_models.created_at IS '创建时间';
|
||
COMMENT ON COLUMN model_gateway_models.updater IS '更新人';
|
||
COMMENT ON COLUMN model_gateway_models.updated_at IS '更新时间';
|
||
COMMENT ON COLUMN model_gateway_models.deleted_at IS '删除时间(软删)';
|
||
|
||
COMMENT ON COLUMN model_gateway_models.model_name IS '模型名称';
|
||
COMMENT ON COLUMN model_gateway_models.model_type IS '模型类型';
|
||
COMMENT ON COLUMN model_gateway_models.operator_name IS '运营商名称';
|
||
COMMENT ON COLUMN model_gateway_models.base_url IS '模型地址';
|
||
COMMENT ON COLUMN model_gateway_models.http_method IS '请求方式 GET/POST';
|
||
COMMENT ON COLUMN model_gateway_models.head_msg IS '请求头信息';
|
||
COMMENT ON COLUMN model_gateway_models.api_key IS '调用凭证/密钥';
|
||
COMMENT ON COLUMN model_gateway_models.is_private IS '是否私有化:0-私有 1-公共';
|
||
COMMENT ON COLUMN model_gateway_models.enabled IS '是否启用:0-停用 1-启用';
|
||
COMMENT ON COLUMN model_gateway_models.is_chat_model IS '是否为对话模型:0-否 1-是';
|
||
COMMENT ON COLUMN model_gateway_models.is_owner IS '1=当前用户创建 0=超级管理员';
|
||
COMMENT ON COLUMN model_gateway_models.call_mode IS '调用模式:0-同步 1-异步 2-流式';
|
||
COMMENT ON COLUMN model_gateway_models.form_json IS '动态表单结构';
|
||
COMMENT ON COLUMN model_gateway_models.request_mapping IS '请求映射';
|
||
COMMENT ON COLUMN model_gateway_models.response_mapping IS '返回映射';
|
||
COMMENT ON COLUMN model_gateway_models.response_body IS '返回主体';
|
||
COMMENT ON COLUMN model_gateway_models.token_config IS 'Token计算配置';
|
||
COMMENT ON COLUMN model_gateway_models.extend_mapping IS '附加映射';
|
||
COMMENT ON COLUMN model_gateway_models.query_config IS '查询/回调配置';
|
||
COMMENT ON COLUMN model_gateway_models.stream_config IS '流式输出配置';
|
||
COMMENT ON COLUMN model_gateway_models.first_frame IS '首帧图片参数';
|
||
COMMENT ON COLUMN model_gateway_models.last_frame IS '尾帧图片参数';
|
||
COMMENT ON COLUMN model_gateway_models.max_concurrency IS '最大并发数';
|
||
COMMENT ON COLUMN model_gateway_models.timeout_seconds IS '调用模型超时(秒)';
|
||
COMMENT ON COLUMN model_gateway_models.retry_times IS '失败重试次数';
|
||
COMMENT ON COLUMN model_gateway_models.response_token_field IS '响应中消耗token的字段映射';
|
||
COMMENT ON COLUMN model_gateway_models.required_fields IS '必选字段列表';
|
||
COMMENT ON COLUMN model_gateway_models.max_tokens IS '最大 token 数,0 表示不传';
|
||
|
||
|
||
|
||
-- =========================
|
||
-- model_gateway_task
|
||
-- =========================
|
||
CREATE TABLE IF NOT EXISTS model_gateway_task (
|
||
id int8 PRIMARY KEY,
|
||
tenant_id int8 NOT NULL DEFAULT 0,
|
||
creator varchar(64) NOT NULL,
|
||
created_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updater varchar(64) NOT NULL,
|
||
updated_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
deleted_at timestamp(6),
|
||
model_name varchar(128) NOT NULL,
|
||
task_id varchar(64) NOT NULL,
|
||
biz_name varchar(128) NOT NULL DEFAULT '',
|
||
callback_url varchar(512) DEFAULT '',
|
||
state int2 NOT NULL DEFAULT 0,
|
||
retry_count int4 NOT NULL DEFAULT 0,
|
||
phase int2 NOT NULL DEFAULT 0,
|
||
tmp_file text DEFAULT '',
|
||
error_msg text DEFAULT '',
|
||
result_file jsonb NOT NULL DEFAULT '{}',
|
||
request_payload jsonb NOT NULL DEFAULT '{}',
|
||
text_result jsonb NOT NULL DEFAULT '{}',
|
||
expend_tokens int8 NOT NULL DEFAULT 0,
|
||
duration_seconds int8 NOT NULL DEFAULT 0,
|
||
epicycle_id varchar(64) NOT NULL DEFAULT ''
|
||
);
|
||
|
||
CREATE UNIQUE INDEX IF NOT EXISTS uk_model_gateway_task_tenant_creator_task_id ON model_gateway_task (tenant_id, creator, task_id);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_task_task_id ON model_gateway_task (task_id);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_task_state ON model_gateway_task (state);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_task_deleted_at ON model_gateway_task (deleted_at);
|
||
|
||
COMMENT ON TABLE model_gateway_task IS '模型网关任务表';
|
||
COMMENT ON COLUMN model_gateway_task.id IS '主键ID';
|
||
COMMENT ON COLUMN model_gateway_task.tenant_id IS '租户ID';
|
||
COMMENT ON COLUMN model_gateway_task.creator IS '创建人';
|
||
COMMENT ON COLUMN model_gateway_task.created_at IS '创建时间';
|
||
COMMENT ON COLUMN model_gateway_task.updater IS '更新人';
|
||
COMMENT ON COLUMN model_gateway_task.updated_at IS '更新时间';
|
||
COMMENT ON COLUMN model_gateway_task.deleted_at IS '删除时间(软删)';
|
||
COMMENT ON COLUMN model_gateway_task.model_name IS '模型名称';
|
||
COMMENT ON COLUMN model_gateway_task.task_id IS '任务ID(对外返回)';
|
||
COMMENT ON COLUMN model_gateway_task.biz_name IS '业务名称(调用方模块/系统)';
|
||
COMMENT ON COLUMN model_gateway_task.callback_url IS '回调地址';
|
||
COMMENT ON COLUMN model_gateway_task.state IS '0排队中/1执行中/2成功/3失败/4已下载';
|
||
COMMENT ON COLUMN model_gateway_task.retry_count IS '已重试次数';
|
||
COMMENT ON COLUMN model_gateway_task.phase IS '执行阶段:0模型阶段/1OSS阶段';
|
||
COMMENT ON COLUMN model_gateway_task.tmp_file IS '临时结果文件路径';
|
||
COMMENT ON COLUMN model_gateway_task.error_msg IS '错误信息';
|
||
COMMENT ON COLUMN model_gateway_task.result_file IS '结果文件:{oss_file, file_type, file_size}';
|
||
COMMENT ON COLUMN model_gateway_task.request_payload IS '请求参数(JSON)';
|
||
COMMENT ON COLUMN model_gateway_task.text_result IS '文本类结果';
|
||
COMMENT ON COLUMN model_gateway_task.expend_tokens IS '消耗token数';
|
||
COMMENT ON COLUMN model_gateway_task.duration_seconds IS '耗时(秒)';
|
||
COMMENT ON COLUMN model_gateway_task.epicycle_id IS '轮次ID';
|
||
|
||
|
||
|
||
-- =========================
|
||
-- model_gateway_log_stat
|
||
-- =========================
|
||
CREATE TABLE IF NOT EXISTS model_gateway_log_stat (
|
||
day date NOT NULL,
|
||
tenant_id int8 NOT NULL DEFAULT 0,
|
||
creator varchar(64) NOT NULL DEFAULT '',
|
||
model_name varchar(128) NOT NULL DEFAULT '',
|
||
request_count int8 NOT NULL DEFAULT 0,
|
||
created_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updated_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
PRIMARY KEY (day, tenant_id, creator, model_name)
|
||
);
|
||
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_log_stat_day ON model_gateway_log_stat (day);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_log_stat_creator ON model_gateway_log_stat (creator);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_log_stat_model_name ON model_gateway_log_stat (model_name);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_log_stat_tenant_day ON model_gateway_log_stat (tenant_id, day);
|
||
|
||
COMMENT ON TABLE model_gateway_log_stat IS '按天统计表';
|
||
COMMENT ON COLUMN model_gateway_log_stat.day IS '天(YYYY-MM-DD)';
|
||
COMMENT ON COLUMN model_gateway_log_stat.tenant_id IS '租户ID';
|
||
COMMENT ON COLUMN model_gateway_log_stat.creator IS '创建人';
|
||
COMMENT ON COLUMN model_gateway_log_stat.model_name IS '模型名称';
|
||
COMMENT ON COLUMN model_gateway_log_stat.request_count IS '请求次数';
|
||
COMMENT ON COLUMN model_gateway_log_stat.created_at IS '创建时间';
|
||
COMMENT ON COLUMN model_gateway_log_stat.updated_at IS '更新时间';
|
||
|
||
|
||
-- =========================
|
||
-- model_gateway_logs_op
|
||
-- =========================
|
||
CREATE TABLE IF NOT EXISTS model_gateway_logs_op (
|
||
id int8 PRIMARY KEY,
|
||
tenant_id int8 NOT NULL DEFAULT 0,
|
||
creator varchar(64) NOT NULL,
|
||
created_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updater varchar(64) NOT NULL,
|
||
updated_at timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
deleted_at timestamp(6),
|
||
ip varchar(64) DEFAULT '',
|
||
user_agent varchar(256) DEFAULT '',
|
||
api_path varchar(256) DEFAULT '',
|
||
http_method varchar(16) DEFAULT '',
|
||
biz_name varchar(128) NOT NULL DEFAULT '',
|
||
model_name varchar(128) NOT NULL DEFAULT '',
|
||
task_id varchar(64) NOT NULL DEFAULT '',
|
||
op_type varchar(64) NOT NULL DEFAULT 'createTask',
|
||
success int2 NOT NULL DEFAULT 1,
|
||
error_msg text DEFAULT '',
|
||
cost_ms int8 NOT NULL DEFAULT 0,
|
||
request_payload jsonb,
|
||
response_payload jsonb
|
||
);
|
||
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_logs_op_task_id ON model_gateway_logs_op (task_id);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_logs_op_biz_name ON model_gateway_logs_op (biz_name);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_logs_op_model_name ON model_gateway_logs_op (model_name);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_logs_op_op_type ON model_gateway_logs_op (op_type);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_logs_op_deleted_at ON model_gateway_logs_op (deleted_at);
|
||
CREATE INDEX IF NOT EXISTS idx_model_gateway_logs_op_tenant_time ON model_gateway_logs_op (tenant_id, created_at);
|
||
|
||
COMMENT ON TABLE model_gateway_logs_op IS '操作日志表';
|
||
COMMENT ON COLUMN model_gateway_logs_op.id IS '主键ID(非自增)';
|
||
COMMENT ON COLUMN model_gateway_logs_op.tenant_id IS '租户ID';
|
||
COMMENT ON COLUMN model_gateway_logs_op.creator IS '创建人';
|
||
COMMENT ON COLUMN model_gateway_logs_op.created_at IS '创建时间';
|
||
COMMENT ON COLUMN model_gateway_logs_op.updater IS '更新人';
|
||
COMMENT ON COLUMN model_gateway_logs_op.updated_at IS '更新时间';
|
||
COMMENT ON COLUMN model_gateway_logs_op.deleted_at IS '删除时间(软删)';
|
||
COMMENT ON COLUMN model_gateway_logs_op.ip IS '客户端IP';
|
||
COMMENT ON COLUMN model_gateway_logs_op.user_agent IS 'User-Agent';
|
||
COMMENT ON COLUMN model_gateway_logs_op.api_path IS '接口路径';
|
||
COMMENT ON COLUMN model_gateway_logs_op.http_method IS 'HTTP方法';
|
||
COMMENT ON COLUMN model_gateway_logs_op.biz_name IS '业务名称(调用方模块/系统)';
|
||
COMMENT ON COLUMN model_gateway_logs_op.model_name IS '模型名称';
|
||
COMMENT ON COLUMN model_gateway_logs_op.task_id IS '任务ID';
|
||
COMMENT ON COLUMN model_gateway_logs_op.op_type IS '操作类型';
|
||
COMMENT ON COLUMN model_gateway_logs_op.success IS '是否成功:1成功/0失败';
|
||
COMMENT ON COLUMN model_gateway_logs_op.error_msg IS '错误信息(失败时)';
|
||
COMMENT ON COLUMN model_gateway_logs_op.cost_ms IS '耗时(毫秒)';
|
||
COMMENT ON COLUMN model_gateway_logs_op.request_payload IS '请求 JSON';
|
||
COMMENT ON COLUMN model_gateway_logs_op.response_payload IS '响应 JSON'; |