Files
zt-dsc/sql/dm/统一对外网关_20251010.sql
chenbowen c0dc0823b6 1.规范增量 SQL 文件命名
2.新增数据总线模块(未完成)
3.新增规则模块(未完成)
4.新增组织编码与外部系统组织编码映射关系表
5.补全 e 办单点登录回调逻辑
2025-10-15 08:59:57 +08:00

242 lines
12 KiB
SQL

/*
* Databus API portal schema for DM8
* Generated on 2025-10-10
*/
-- ----------------------------
-- Table structure for databus_api_definition
-- ----------------------------
CREATE TABLE databus_api_definition (
id BIGINT NOT NULL PRIMARY KEY,
tenant_id BIGINT NOT NULL,
api_code VARCHAR(128) NOT NULL,
uri_pattern VARCHAR(256) NOT NULL,
http_method VARCHAR(16) NOT NULL,
version VARCHAR(32) NOT NULL,
status SMALLINT DEFAULT 0 NOT NULL,
description VARCHAR(512),
auth_policy_id BIGINT,
rate_limit_id BIGINT,
response_template CLOB,
cache_strategy VARCHAR(128),
updated_at DATETIME,
grey_released BIT DEFAULT '0' NOT NULL,
creator VARCHAR(64) DEFAULT '' NOT NULL,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
updater VARCHAR(64) DEFAULT '' NOT NULL,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
deleted BIT DEFAULT '0' NOT NULL
);
CREATE UNIQUE INDEX uk_databus_api_definition_code_ver ON databus_api_definition (tenant_id, api_code, version);
CREATE INDEX idx_databus_api_definition_status ON databus_api_definition (tenant_id, status);
CREATE INDEX idx_databus_api_definition_policy ON databus_api_definition (tenant_id, auth_policy_id, rate_limit_id);
COMMENT ON TABLE databus_api_definition IS '统一外部 API 门户 - API 定义表';
COMMENT ON COLUMN databus_api_definition.id IS '主键 ID';
COMMENT ON COLUMN databus_api_definition.tenant_id IS '租户编号';
COMMENT ON COLUMN databus_api_definition.api_code IS 'API 编码';
COMMENT ON COLUMN databus_api_definition.uri_pattern IS '匹配路径模板';
COMMENT ON COLUMN databus_api_definition.http_method IS 'HTTP 方法';
COMMENT ON COLUMN databus_api_definition.version IS '版本号';
COMMENT ON COLUMN databus_api_definition.status IS '发布状态';
COMMENT ON COLUMN databus_api_definition.description IS '描述信息';
COMMENT ON COLUMN databus_api_definition.auth_policy_id IS '认证策略 ID';
COMMENT ON COLUMN databus_api_definition.rate_limit_id IS '限流策略 ID';
COMMENT ON COLUMN databus_api_definition.response_template IS '响应模板 JSON';
COMMENT ON COLUMN databus_api_definition.cache_strategy IS '缓存策略配置';
COMMENT ON COLUMN databus_api_definition.updated_at IS '业务更新时间';
COMMENT ON COLUMN databus_api_definition.grey_released IS '灰度发布标记';
COMMENT ON COLUMN databus_api_definition.creator IS '创建者';
COMMENT ON COLUMN databus_api_definition.create_time IS '创建时间';
COMMENT ON COLUMN databus_api_definition.updater IS '更新者';
COMMENT ON COLUMN databus_api_definition.update_time IS '更新时间';
COMMENT ON COLUMN databus_api_definition.deleted IS '逻辑删除标记';
-- ----------------------------
-- Table structure for databus_api_flow_publish
-- ----------------------------
CREATE TABLE databus_api_flow_publish (
id BIGINT NOT NULL PRIMARY KEY,
tenant_id BIGINT NOT NULL,
api_id BIGINT NOT NULL,
release_tag VARCHAR(64),
snapshot CLOB,
status VARCHAR(32),
active BIT DEFAULT '0' NOT NULL,
description VARCHAR(512),
creator VARCHAR(64) DEFAULT '' NOT NULL,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
updater VARCHAR(64) DEFAULT '' NOT NULL,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
deleted BIT DEFAULT '0' NOT NULL
);
CREATE INDEX idx_databus_api_flow_publish_api ON databus_api_flow_publish (tenant_id, api_id, active);
COMMENT ON TABLE databus_api_flow_publish IS '统一外部 API 门户 - 发布记录表';
COMMENT ON COLUMN databus_api_flow_publish.id IS '主键 ID';
COMMENT ON COLUMN databus_api_flow_publish.tenant_id IS '租户编号';
COMMENT ON COLUMN databus_api_flow_publish.api_id IS '关联的 API ID';
COMMENT ON COLUMN databus_api_flow_publish.release_tag IS '发布批次标识';
COMMENT ON COLUMN databus_api_flow_publish.snapshot IS '配置快照 JSON';
COMMENT ON COLUMN databus_api_flow_publish.status IS '发布状态';
COMMENT ON COLUMN databus_api_flow_publish.active IS '是否当前生效';
COMMENT ON COLUMN databus_api_flow_publish.description IS '备注信息';
COMMENT ON COLUMN databus_api_flow_publish.creator IS '创建者';
COMMENT ON COLUMN databus_api_flow_publish.create_time IS '创建时间';
COMMENT ON COLUMN databus_api_flow_publish.updater IS '更新者';
COMMENT ON COLUMN databus_api_flow_publish.update_time IS '更新时间';
COMMENT ON COLUMN databus_api_flow_publish.deleted IS '逻辑删除标记';
-- ----------------------------
-- Table structure for databus_policy_auth
-- ----------------------------
CREATE TABLE databus_policy_auth (
id BIGINT NOT NULL PRIMARY KEY,
tenant_id BIGINT NOT NULL,
name VARCHAR(128) NOT NULL,
type VARCHAR(64) NOT NULL,
config CLOB,
description VARCHAR(512),
creator VARCHAR(64) DEFAULT '' NOT NULL,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
updater VARCHAR(64) DEFAULT '' NOT NULL,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
deleted BIT DEFAULT '0' NOT NULL
);
CREATE UNIQUE INDEX uk_databus_policy_auth_name ON databus_policy_auth (tenant_id, name);
COMMENT ON TABLE databus_policy_auth IS '统一外部 API 门户 - 认证策略表';
COMMENT ON COLUMN databus_policy_auth.id IS '主键 ID';
COMMENT ON COLUMN databus_policy_auth.tenant_id IS '租户编号';
COMMENT ON COLUMN databus_policy_auth.name IS '策略名称';
COMMENT ON COLUMN databus_policy_auth.type IS '策略类型';
COMMENT ON COLUMN databus_policy_auth.config IS '策略配置 JSON';
COMMENT ON COLUMN databus_policy_auth.description IS '描述信息';
COMMENT ON COLUMN databus_policy_auth.creator IS '创建者';
COMMENT ON COLUMN databus_policy_auth.create_time IS '创建时间';
COMMENT ON COLUMN databus_policy_auth.updater IS '更新者';
COMMENT ON COLUMN databus_policy_auth.update_time IS '更新时间';
COMMENT ON COLUMN databus_policy_auth.deleted IS '逻辑删除标记';
-- ----------------------------
-- Table structure for databus_policy_rate_limit
-- ----------------------------
CREATE TABLE databus_policy_rate_limit (
id BIGINT NOT NULL PRIMARY KEY,
tenant_id BIGINT NOT NULL,
name VARCHAR(128) NOT NULL,
type VARCHAR(64) NOT NULL,
config CLOB,
description VARCHAR(512),
creator VARCHAR(64) DEFAULT '' NOT NULL,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
updater VARCHAR(64) DEFAULT '' NOT NULL,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
deleted BIT DEFAULT '0' NOT NULL
);
CREATE UNIQUE INDEX uk_databus_policy_rate_limit_name ON databus_policy_rate_limit (tenant_id, name);
COMMENT ON TABLE databus_policy_rate_limit IS '统一外部 API 门户 - 限流策略表';
COMMENT ON COLUMN databus_policy_rate_limit.id IS '主键 ID';
COMMENT ON COLUMN databus_policy_rate_limit.tenant_id IS '租户编号';
COMMENT ON COLUMN databus_policy_rate_limit.name IS '策略名称';
COMMENT ON COLUMN databus_policy_rate_limit.type IS '策略类型';
COMMENT ON COLUMN databus_policy_rate_limit.config IS '策略配置 JSON';
COMMENT ON COLUMN databus_policy_rate_limit.description IS '描述信息';
COMMENT ON COLUMN databus_policy_rate_limit.creator IS '创建者';
COMMENT ON COLUMN databus_policy_rate_limit.create_time IS '创建时间';
COMMENT ON COLUMN databus_policy_rate_limit.updater IS '更新者';
COMMENT ON COLUMN databus_policy_rate_limit.update_time IS '更新时间';
COMMENT ON COLUMN databus_policy_rate_limit.deleted IS '逻辑删除标记';
-- ----------------------------
-- Table structure for databus_api_step
-- ----------------------------
CREATE TABLE databus_api_step (
id BIGINT NOT NULL PRIMARY KEY,
tenant_id BIGINT NOT NULL,
api_id BIGINT NOT NULL,
step_order INT DEFAULT 0 NOT NULL,
parallel_group VARCHAR(64),
type VARCHAR(32) NOT NULL,
target_endpoint VARCHAR(512),
request_mapping_expr CLOB,
response_mapping_expr CLOB,
transform_id BIGINT,
timeout BIGINT,
retry_strategy CLOB,
fallback_strategy CLOB,
condition_expr CLOB,
stop_on_error BIT DEFAULT '0' NOT NULL,
creator VARCHAR(64) DEFAULT '' NOT NULL,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
updater VARCHAR(64) DEFAULT '' NOT NULL,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
deleted BIT DEFAULT '0' NOT NULL
);
CREATE INDEX idx_databus_api_step_api_order ON databus_api_step (tenant_id, api_id, parallel_group, step_order);
COMMENT ON TABLE databus_api_step IS '统一外部 API 门户 - 编排步骤表';
COMMENT ON COLUMN databus_api_step.id IS '主键 ID';
COMMENT ON COLUMN databus_api_step.tenant_id IS '租户编号';
COMMENT ON COLUMN databus_api_step.api_id IS '关联的 API ID';
COMMENT ON COLUMN databus_api_step.step_order IS '执行顺序';
COMMENT ON COLUMN databus_api_step.parallel_group IS '并行分组标识';
COMMENT ON COLUMN databus_api_step.type IS '步骤类型';
COMMENT ON COLUMN databus_api_step.target_endpoint IS '目标端点';
COMMENT ON COLUMN databus_api_step.request_mapping_expr IS '请求映射表达式';
COMMENT ON COLUMN databus_api_step.response_mapping_expr IS '响应映射表达式';
COMMENT ON COLUMN databus_api_step.transform_id IS '默认变换 ID';
COMMENT ON COLUMN databus_api_step.timeout IS '超时时间(毫秒)';
COMMENT ON COLUMN databus_api_step.retry_strategy IS '重试策略 JSON';
COMMENT ON COLUMN databus_api_step.fallback_strategy IS '降级策略 JSON';
COMMENT ON COLUMN databus_api_step.condition_expr IS '执行条件表达式';
COMMENT ON COLUMN databus_api_step.stop_on_error IS '出错是否终止';
COMMENT ON COLUMN databus_api_step.creator IS '创建者';
COMMENT ON COLUMN databus_api_step.create_time IS '创建时间';
COMMENT ON COLUMN databus_api_step.updater IS '更新者';
COMMENT ON COLUMN databus_api_step.update_time IS '更新时间';
COMMENT ON COLUMN databus_api_step.deleted IS '逻辑删除标记';
-- ----------------------------
-- Table structure for databus_api_transform
-- ----------------------------
CREATE TABLE databus_api_transform (
id BIGINT NOT NULL PRIMARY KEY,
tenant_id BIGINT NOT NULL,
api_id BIGINT,
step_id BIGINT,
phase VARCHAR(32) NOT NULL,
expression_type VARCHAR(32) NOT NULL,
expression CLOB NOT NULL,
description VARCHAR(512),
creator VARCHAR(64) DEFAULT '' NOT NULL,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
updater VARCHAR(64) DEFAULT '' NOT NULL,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP NOT NULL,
deleted BIT DEFAULT '0' NOT NULL
);
CREATE INDEX idx_databus_api_transform_api ON databus_api_transform (tenant_id, api_id);
CREATE INDEX idx_databus_api_transform_step ON databus_api_transform (tenant_id, step_id);
COMMENT ON TABLE databus_api_transform IS '统一外部 API 门户 - 变换配置表';
COMMENT ON COLUMN databus_api_transform.id IS '主键 ID';
COMMENT ON COLUMN databus_api_transform.tenant_id IS '租户编号';
COMMENT ON COLUMN databus_api_transform.api_id IS '关联的 API ID';
COMMENT ON COLUMN databus_api_transform.step_id IS '关联的步骤 ID';
COMMENT ON COLUMN databus_api_transform.phase IS '执行阶段';
COMMENT ON COLUMN databus_api_transform.expression_type IS '表达式类型';
COMMENT ON COLUMN databus_api_transform.expression IS '表达式内容';
COMMENT ON COLUMN databus_api_transform.description IS '描述信息';
COMMENT ON COLUMN databus_api_transform.creator IS '创建者';
COMMENT ON COLUMN databus_api_transform.create_time IS '创建时间';
COMMENT ON COLUMN databus_api_transform.updater IS '更新者';
COMMENT ON COLUMN databus_api_transform.update_time IS '更新时间';
COMMENT ON COLUMN databus_api_transform.deleted IS '逻辑删除标记';