95 lines
8.6 KiB
SQL
95 lines
8.6 KiB
SQL
-- 镭射卡 v3 表/字段/索引/约束备注(由 migrate_laser_card_v3_tables.sql 引用,亦可单独执行)
|
||
|
||
COMMENT ON TABLE public.laser_card_templates IS
|
||
'镭射卡预设模板表。内置 5 套预设(dream/classic/holoFull/ice/sunset),与前端 laserPresets.js 对齐;本期只读种子,无管理端 CRUD。';
|
||
|
||
COMMENT ON COLUMN public.laser_card_templates.id IS '主键,自增';
|
||
COMMENT ON COLUMN public.laser_card_templates.template_code IS '业务编码,与五图 presetId 一致:dream | classic | holoFull | ice | sunset';
|
||
COMMENT ON COLUMN public.laser_card_templates.name IS 'C 端展示名称,如「梦幻」「全息」';
|
||
COMMENT ON COLUMN public.laser_card_templates.description IS '模板描述,可选';
|
||
COMMENT ON COLUMN public.laser_card_templates.status IS '发布状态:published(可用)| archived(下线)';
|
||
COMMENT ON COLUMN public.laser_card_templates.version IS '模板版本号;与 template_code 联合唯一(uk_lct_code_version)';
|
||
COMMENT ON COLUMN public.laser_card_templates.thumbnail_oss_key IS '列表缩略图 OSS 对象键,可选';
|
||
COMMENT ON COLUMN public.laser_card_templates.backdrop_options IS '底纹选项 JSON 数组,元素含 id/label/oss_key,如 liquidBlue → static/laser-bg/laser-bg-1.png';
|
||
COMMENT ON COLUMN public.laser_card_templates.render_config IS '默认渲染参数 JSON:style/angle/beam/backdrop/laserStrength 等,建议 < 16KB';
|
||
COMMENT ON COLUMN public.laser_card_templates.engine_min_version IS '最低客户端合成器版本,默认 compositor-1.0.0';
|
||
COMMENT ON COLUMN public.laser_card_templates.sort_order IS '模板列表排序,越小越靠前';
|
||
COMMENT ON COLUMN public.laser_card_templates.star_id IS '所属明星/星球 ID;0 表示全站通用模板';
|
||
COMMENT ON COLUMN public.laser_card_templates.created_by IS '创建人用户 ID;种子数据填 0';
|
||
COMMENT ON COLUMN public.laser_card_templates.created_at IS '创建时间,毫秒时间戳';
|
||
COMMENT ON COLUMN public.laser_card_templates.updated_at IS '更新时间,毫秒时间戳';
|
||
COMMENT ON COLUMN public.laser_card_templates.deleted_at IS '软删除时间,毫秒时间戳;NULL 表示未删除';
|
||
|
||
COMMENT ON INDEX public.uk_lct_code_version IS '同 template_code + version 在未删除行内唯一';
|
||
COMMENT ON INDEX public.idx_lct_status_star IS '按发布状态与 star_id 筛选模板列表';
|
||
|
||
COMMENT ON TABLE public.laser_card_instances IS
|
||
'镭射卡业务实例表。一次「上传 → 五图选卡 → 铸造」对应一行;铸造前素材存 materials_snapshot,成功后回填 asset_id、mint_order_id。品类/工艺不写本表,见 assets.tags(cast:star_card + craft:laser)。';
|
||
|
||
COMMENT ON COLUMN public.laser_card_instances.id IS '主键,自增;对内使用';
|
||
COMMENT ON COLUMN public.laser_card_instances.instance_no IS '业务单号,UK;格式 LC + yyyyMMddHHmmss + 6 位随机';
|
||
COMMENT ON COLUMN public.laser_card_instances.instance_ulid IS '对外实例 ID,UK;如 lc_inst_01HXYZ...,API 路径参数';
|
||
COMMENT ON COLUMN public.laser_card_instances.template_id IS 'FK → laser_card_templates.id,用户选中的预设';
|
||
COMMENT ON COLUMN public.laser_card_instances.template_code IS '模板编码冗余,避免列表 JOIN templates';
|
||
COMMENT ON COLUMN public.laser_card_instances.template_version IS '创建实例时锁定的模板版本快照';
|
||
COMMENT ON COLUMN public.laser_card_instances.owner_user_id IS '持有者用户 ID;鉴权须等于 JWT user_id';
|
||
COMMENT ON COLUMN public.laser_card_instances.star_id IS '多星隔离:所属明星/星球 ID(非「星卡」品类)';
|
||
COMMENT ON COLUMN public.laser_card_instances.status IS '状态机:rendered(已选卡未铸造)| minting(铸造中)| minted(已完成)';
|
||
COMMENT ON COLUMN public.laser_card_instances.client_request_id IS '客户端幂等 UUID;与 owner_user_id 联合唯一(uk_lci_user_client_req)';
|
||
COMMENT ON COLUMN public.laser_card_instances.render_config IS '用户最终渲染参数 JSON 快照,可选';
|
||
COMMENT ON COLUMN public.laser_card_instances.materials_snapshot IS
|
||
'铸造前素材 OSS 清单 JSON 数组(3–4 项,无抠图则无 cutout)。每项字段:role(source|cutout|backdrop|composite)、oss_key、hash、width、height、mime_type、file_size、preset_id(仅 backdrop/composite)。不存 materials.id;铸造后写入 asset_material_relations';
|
||
COMMENT ON COLUMN public.laser_card_instances.composite_oss_key IS '用户选中的合成图 OSS key,通常等于 snapshot 中 composite 项';
|
||
COMMENT ON COLUMN public.laser_card_instances.composite_material_id IS '铸造成功后回填 materials.id(对应 asset_material_relations.main 层)';
|
||
COMMENT ON COLUMN public.laser_card_instances.asset_id IS 'FK → assets.id;铸造成功后回填,铸造前为 NULL';
|
||
COMMENT ON COLUMN public.laser_card_instances.mint_order_id IS 'FK → mint_orders.order_id;发起铸造时关联';
|
||
COMMENT ON COLUMN public.laser_card_instances.idempotency_key IS '最后一次写操作的幂等键,可选';
|
||
COMMENT ON COLUMN public.laser_card_instances.version IS '乐观锁版本号,每次更新实例 +1';
|
||
COMMENT ON COLUMN public.laser_card_instances.created_at IS '创建时间,毫秒时间戳';
|
||
COMMENT ON COLUMN public.laser_card_instances.updated_at IS '更新时间,毫秒时间戳';
|
||
COMMENT ON COLUMN public.laser_card_instances.deleted_at IS '软删除时间,毫秒时间戳;NULL 表示未删除';
|
||
|
||
COMMENT ON INDEX public.uk_lci_instance_no IS '业务单号唯一';
|
||
COMMENT ON INDEX public.uk_lci_instance_ulid IS '对外实例 ID 唯一';
|
||
COMMENT ON INDEX public.uk_lci_user_client_req IS '同一用户下 client_request_id 幂等(未删除且非空)';
|
||
COMMENT ON INDEX public.idx_lci_owner_status IS '按用户与状态查实例列表';
|
||
COMMENT ON INDEX public.idx_lci_asset IS '按已铸造资产反查实例';
|
||
COMMENT ON INDEX public.idx_lci_star_created IS '按星球与时间倒序列表';
|
||
|
||
COMMENT ON TABLE public.laser_card_operation_logs IS
|
||
'镭射卡操作审计流水表。只追加不更新;记录 create_instance / mint_start / mint_success / mint_fail 等;payload_json 禁止存大图或 base64。';
|
||
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.id IS '主键,自增';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.instance_id IS 'FK → laser_card_instances.id;实例删除时级联删除日志';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.instance_no IS '实例业务单号冗余,便于按单号检索';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.operator_user_id IS '操作人用户 ID';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.action IS '动作:create_instance | generate_variants | mint_start | mint_success | mint_fail';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.status_before IS '变更前实例 status,可选';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.status_after IS '变更后实例 status,可选';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.request_id IS '请求追踪 ID,可选';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.payload_json IS '请求摘要 JSON,禁止存图片二进制或 base64';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.result_json IS '响应摘要 JSON,可选';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.ip_address IS '客户端 IP,IPv4/IPv6';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.user_agent IS '客户端 User-Agent';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.latency_ms IS '接口耗时(毫秒),可选';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.err_code IS '失败时的业务错误码,可选';
|
||
COMMENT ON COLUMN public.laser_card_operation_logs.created_at IS '日志创建时间,毫秒时间戳';
|
||
|
||
COMMENT ON INDEX public.idx_lclog_instance_time IS '按实例查操作历史(时间倒序)';
|
||
COMMENT ON INDEX public.idx_lclog_operator_time IS '按操作人查历史';
|
||
COMMENT ON INDEX public.idx_lclog_action_time IS '按动作类型统计与排查';
|
||
|
||
COMMENT ON CONSTRAINT fk_lci_template ON public.laser_card_instances IS
|
||
'关联所选镭射预设模板';
|
||
COMMENT ON CONSTRAINT fk_lci_asset ON public.laser_card_instances IS
|
||
'铸造成功后的藏品 assets.id;删除资产时置 NULL';
|
||
COMMENT ON CONSTRAINT fk_lci_mint_order ON public.laser_card_instances IS
|
||
'关联铸造订单 mint_orders.order_id';
|
||
COMMENT ON CONSTRAINT fk_lci_composite_material ON public.laser_card_instances IS
|
||
'选中合成图在 materials 表中的主键(main 层)';
|
||
COMMENT ON CONSTRAINT chk_lci_status ON public.laser_card_instances IS
|
||
'实例状态枚举:rendered | minting | minted';
|
||
|
||
COMMENT ON CONSTRAINT fk_lclog_instance ON public.laser_card_operation_logs IS
|
||
'关联镭射实例;实例删除时级联删除审计日志';
|