113 lines
7.1 KiB
PL/PgSQL
113 lines
7.1 KiB
PL/PgSQL
---------------------------------- 国家主表 ----------------------------------
|
||
|
||
-- 创建国家ID记录表(主表,存储基础主键+通用字段)
|
||
CREATE TABLE IF NOT EXISTS countries (
|
||
country_id UUID PRIMARY KEY DEFAULT uuidv7(),
|
||
deleted boolean DEFAULT false,
|
||
create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||
);
|
||
|
||
-- 表注释
|
||
COMMENT ON TABLE countries IS '国家主表,仅存储国家基础主键及通用公共字段,关联国家/地区子表';
|
||
-- 字段注释
|
||
COMMENT ON COLUMN countries.country_id IS '国家主键ID,PG18原生UUIDv7,作为所有子表的关联外键';
|
||
COMMENT ON COLUMN countries.deleted IS '逻辑删除标识,false-未删除,true-已删除,默认未删除';
|
||
COMMENT ON COLUMN countries.create_time IS '记录创建时间,默认当前系统时间,不可手动修改';
|
||
COMMENT ON COLUMN countries.update_time IS '记录最后更新时间,默认当前系统时间';
|
||
|
||
-- 创建update_time自动刷新触发器函数(所有表复用)
|
||
CREATE OR REPLACE FUNCTION update_table_modify_time()
|
||
RETURNS TRIGGER AS $$
|
||
BEGIN
|
||
NEW.update_time = CURRENT_TIMESTAMP;
|
||
RETURN NEW;
|
||
END;
|
||
$$ LANGUAGE plpgsql;
|
||
-- 绑定触发器到国家主表
|
||
CREATE TRIGGER tr_countries_update_time
|
||
BEFORE UPDATE ON countries
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_table_modify_time();
|
||
|
||
|
||
|
||
---------------------------------- 国家核心信息表 ----------------------------------
|
||
|
||
-- 创建国家核心信息记录表(子表,存储国家编码/名称等核心信息)
|
||
CREATE TABLE IF NOT EXISTS country_core_infos (
|
||
core_id UUID PRIMARY KEY DEFAULT uuidv7(),
|
||
country_id UUID NOT NULL,
|
||
country_code VARCHAR(5) NOT NULL, -- 如CN(中国)/US(美国),遵循ISO 3166-1
|
||
country_cn_short_name VARCHAR(50) NOT NULL, -- 如中国/美国,中文简称
|
||
deleted boolean DEFAULT false,
|
||
create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
-- 外键约束:关联国家主表,保证数据一致性(删除主表时级联置空/禁止删除,按需选择)
|
||
CONSTRAINT fk_country_core_infos_country_id
|
||
FOREIGN KEY (country_id) REFERENCES countries (country_id)
|
||
ON DELETE RESTRICT -- 主表国家未删除时,禁止删除子表信息(推荐生产使用)
|
||
-- ON DELETE SET NULL -- 可选:主表删除时,子表country_id置空(适合软删除场景)
|
||
);
|
||
|
||
-- 表注释
|
||
COMMENT ON TABLE country_core_infos IS '国家核心信息子表,存储国家编码、中文名称等专属信息,与国家主表一对一关联';
|
||
-- 字段注释
|
||
COMMENT ON COLUMN country_core_infos.core_id IS '子表主键ID,PG18原生UUIDv7';
|
||
COMMENT ON COLUMN country_core_infos.country_id IS '关联国家主表countries.country_id,外键约束';
|
||
COMMENT ON COLUMN country_core_infos.country_code IS '国家二位编码,遵循ISO 3166-1,如CN(中国)/US(美国),唯一标识国家';
|
||
COMMENT ON COLUMN country_core_infos.country_cn_short_name IS '国家中文简称,如中国/美国,业务展示专用';
|
||
COMMENT ON COLUMN country_core_infos.deleted IS '逻辑删除标识,false-未删除,true-已删除,默认未删除';
|
||
COMMENT ON COLUMN country_core_infos.create_time IS '记录创建时间,默认当前系统时间,不可手动修改';
|
||
COMMENT ON COLUMN country_core_infos.update_time IS '记录最后更新时间,更新时触发器自动刷新';
|
||
|
||
-- 索引:优化高频业务查询(核心)
|
||
CREATE UNIQUE INDEX uk_country_core_infos_code ON country_core_infos (country_code) WHERE deleted = false; -- 唯一索引:国家编码不重复(未删除数据)
|
||
CREATE INDEX idx_country_core_infos_country_id ON country_core_infos (country_id, deleted); -- 联合索引:按国家ID关联查询+过滤删除数据
|
||
CREATE INDEX idx_country_core_infos_name ON country_core_infos (country_cn_short_name, deleted); -- 联合索引:按国家名称模糊查询+过滤删除数据
|
||
|
||
-- 绑定触发器:更新时自动刷新update_time
|
||
CREATE TRIGGER tr_country_core_infos_update_time
|
||
BEFORE UPDATE ON country_core_infos
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_table_modify_time();
|
||
|
||
|
||
---------------------------------- 国家地区核心信息表 ----------------------------------
|
||
|
||
-- 创建国家地区信息记录表(子表,存储国家下属地区编码/名称等信息,如中国香港/美国纽约)
|
||
CREATE TABLE IF NOT EXISTS country_region_core_infos (
|
||
region_id UUID PRIMARY KEY DEFAULT uuidv7(),
|
||
country_id UUID NOT NULL,
|
||
region_code VARCHAR(5) NOT NULL, -- 如HK(香港)/TW(台湾)/NYC(纽约),建议按 国家码-地区码 设计如CN-HK
|
||
region_cn_short_name VARCHAR(50) NOT NULL, -- 如香港/台湾/纽约,中文简称
|
||
deleted boolean DEFAULT false,
|
||
create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
-- 外键约束:关联国家主表,保证数据一致性
|
||
CONSTRAINT fk_country_region_core_infos_country_id
|
||
FOREIGN KEY (country_id) REFERENCES countries (country_id)
|
||
ON DELETE RESTRICT -- 主表国家未删除时,禁止删除子表地区信息(推荐生产使用)
|
||
);
|
||
|
||
-- 表注释
|
||
COMMENT ON TABLE country_region_core_infos IS '国家地区核心信息子表,存储国家下属地区编码、中文名称等信息,与国家主表一对多关联,支持区分中国香港/澳门/台湾等地区';
|
||
-- 字段注释
|
||
COMMENT ON COLUMN country_region_core_infos.region_id IS '子表主键ID,PG18原生UUIDv7';
|
||
COMMENT ON COLUMN country_region_core_infos.country_id IS '关联国家主表countries.country_id,外键约束,标识地区所属国家';
|
||
COMMENT ON COLUMN country_region_core_infos.region_code IS '地区编码,如HK(香港)/TW(台湾)/NYC(纽约),建议遵循ISO 3166-2设计为CN-HK/CN-TW';
|
||
COMMENT ON COLUMN country_region_core_infos.region_cn_short_name IS '地区中文简称,如香港/台湾/纽约,业务展示专用';
|
||
COMMENT ON COLUMN country_region_core_infos.deleted IS '逻辑删除标识,false-未删除,true-已删除,默认未删除';
|
||
COMMENT ON COLUMN country_region_core_infos.create_time IS '记录创建时间,默认当前系统时间,不可手动修改';
|
||
COMMENT ON COLUMN country_region_core_infos.update_time IS '记录最后更新时间,更新时触发器自动刷新';
|
||
|
||
-- 索引:优化高频业务查询(核心)
|
||
CREATE UNIQUE INDEX uk_country_region_core_infos_country_region ON country_region_core_infos (country_id, region_code) WHERE deleted = false; -- 唯一索引:同一国家下地区编码不重复(未删除数据)
|
||
CREATE INDEX idx_country_region_core_infos_country_id ON country_region_core_infos (country_id, deleted); -- 联合索引:按国家ID查询下属所有地区+过滤删除数据
|
||
CREATE INDEX idx_country_region_core_infos_name ON country_region_core_infos (region_cn_short_name, deleted); -- 联合索引:按地区名称模糊查询+过滤删除数据
|
||
|
||
-- 绑定触发器:更新时自动刷新update_time
|
||
CREATE TRIGGER tr_country_region_core_infos_update_time
|
||
BEFORE UPDATE ON country_region_core_infos
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_table_modify_time(); |