Skip to content

文件元数据

文件元数据的数据结构设计,项目使用时,自行实现 MetadataRepository 接口类并适配数据库,官方演示仓库仅默认提供 MySQL 实现。

表设计

NameTypeLengthNot NullVirtualKeyComment
idbigint20TrueFalseTrue自增ID
file_keyvarchar50TrueFalse文件KEY
file_md5varchar50FalseFalse文件MD5值
file_namevarchar255TrueFalse文件名
file_mime_typevarchar128FalseFalseMIME类型
file_suffixvarchar20FalseFalse文件后缀
file_sizebigint20FalseFalse文件大小
is_previewtinyint1FalseFalse预览图 0:无 1:有
is_privatetinyint1FalseFalse是否私有 0:否 1:是
bucketvarchar20TrueFalse存储桶
bucket_pathvarchar20TrueFalse存储桶路径
upload_idvarchar255FalseFalse上传任务id
is_finishedtinyint1TrueFalse状态 0:未完成 1:已完成
is_parttinyint1FalseFalse是否分块 0:否 1:是
part_numberint4FalseFalse分块数量
create_timedatetimeTrueFalse创建时间
create_uservarchar255TrueFalse创建用户
update_timedatetimeTrueFalse更新时间
update_uservarchar255TrueFalse更新用户

部分字段解析

  • file_key 文件KEY,该字段全表唯一,为自动生成的32位UUID。每次上传文件均生成新的文件KEY,即便是秒传的相同MD5文件也会生成新的文件KEY。
  • file_md5 文件MD5值,该字段是文件的HASH值,用于对应实际在 minio 桶中存储的文件。
  • file_name 文件名,文件上传时本地原始文件名称,含扩展名。
  • file_mime_type 内容类型,根据文件名中的扩展名进行识别,对应 minio 桶中文件的 Content-Type 属性。
  • file_suffix 文件后缀,即扩展名。
  • bucket 和 bucket_path 存储桶和路径,用于保存文件在 minio 中存储的桶和路径,bucket + bucket_path + file_md5 即为文件在 minio 中的物理位置。
  • upload_id 上传任务id,对应 minio 官方 SDK 中 uploadTaskId 字段。在进行分片上传时生成该字段,断点续传时判断是否能续传也会用到该字段。
  • is_finished 状态,文件是否上传完成。

MySQL脚本

CREATE TABLE `file_metadata_info` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `file_key` varchar(50) NOT NULL COMMENT '文件KEY',
  `file_md5` varchar(50) DEFAULT NULL COMMENT '文件md5',
  `file_name` varchar(255) NOT NULL COMMENT '文件名',
  `file_mime_type` varchar(128) DEFAULT NULL COMMENT 'MIME类型',
  `file_suffix` varchar(20) DEFAULT NULL COMMENT '文件后缀',
  `file_size` bigint(20) DEFAULT NULL COMMENT '文件大小',
  `is_preview` tinyint(1) DEFAULT '0' COMMENT '预览图 0:无 1:有',
  `is_private` tinyint(1) DEFAULT '0' COMMENT '是否私有 0:否 1:是',
  `bucket` varchar(20) NOT NULL COMMENT '存储桶',
  `bucket_path` varchar(20) NOT NULL COMMENT '存储桶路径',
  `upload_id` varchar(255) DEFAULT NULL COMMENT '上传任务id',
  `is_finished` tinyint(1) NOT NULL DEFAULT '0' COMMENT '状态 0:未完成 1:已完成',
  `is_part` tinyint(1) DEFAULT NULL COMMENT '是否分块 0:否 1:是',
  `part_number` int(4) DEFAULT NULL COMMENT '分块数量',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `create_user` varchar(255) NOT NULL COMMENT '创建用户',
  `update_time` datetime NOT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  `update_user` varchar(255) NOT NULL COMMENT '更新用户',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `INDEX_KEY` (`file_key`),
  KEY `INDEX_MD5` (`file_md5`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='文件元数据信息表';