- 新增博客设置数据库表结构及实体类定义 - 实现博客设置的查询与更新接口及服务层逻辑 - 实现管理端博客设置控制器,支持修改和查询博客设置详情 - 实现文件上传接口和服务,支持通过Rustfs上传文件 - 集成Rustfs客户端配置,支持与Rustfs存储系统交互 - 新增统一响应及异常处理,文件上传异常抛出自定义业务异常 - 更新错误码枚举,添加文件上传失败的错误码定义 - 增加请求参数校验,确保博客设置更新接口数据有效性 - 添加日志记录,跟踪文件上传流程及错误信息
188 lines
8.8 KiB
PL/PgSQL
188 lines
8.8 KiB
PL/PgSQL
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
-- 1. 创建一个函数,用于在数据更新时自动修改 update_time 字段
|
||
CREATE OR REPLACE FUNCTION set_update_time()
|
||
RETURNS TRIGGER AS
|
||
$$
|
||
BEGIN
|
||
NEW.update_time = NOW();
|
||
RETURN NEW;
|
||
END;
|
||
$$ LANGUAGE plpgsql;
|
||
-- 2. 创建表(使用 BOOLEAN 替代 SMALLINT for is_deleted)
|
||
CREATE TABLE t_user
|
||
(
|
||
id BIGSERIAL PRIMARY KEY,
|
||
username VARCHAR(60) NOT NULL UNIQUE,
|
||
password VARCHAR(60) NOT NULL,
|
||
create_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW(),
|
||
-- WITH TIME ZONE 是更严谨的选择
|
||
update_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW(),
|
||
-- 使用 BOOLEAN 逻辑删除,DEFAULT FALSE 对应 '0:未删除'
|
||
is_deleted BOOLEAN NOT NULL DEFAULT FALSE
|
||
);
|
||
-- 3. 创建触发器,在每次 UPDATE 操作前调用函数
|
||
CREATE TRIGGER set_t_user_update_time
|
||
BEFORE UPDATE
|
||
ON t_user
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION set_update_time();
|
||
-- 添加注释
|
||
COMMENT ON TABLE t_user IS '用户表(优化版)';
|
||
COMMENT ON COLUMN t_user.is_deleted IS '逻辑删除:FALSE:未删除 TRUE:已删除';
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
CREATE TABLE t_user_role
|
||
(
|
||
id BIGSERIAL PRIMARY KEY,
|
||
username VARCHAR(60) NOT NULL,
|
||
role_name VARCHAR(60) NOT NULL, -- 重命名为 role_name 避免关键字冲突
|
||
create_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW()
|
||
);
|
||
|
||
CREATE INDEX idx_username ON t_user_role (username);
|
||
|
||
COMMENT ON COLUMN t_user_role.role_name IS '角色名称';
|
||
-- 为 t_user_role 表创建触发器
|
||
CREATE TRIGGER set_t_user_role_update_time
|
||
BEFORE UPDATE
|
||
ON t_user_role
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION set_update_time();
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
CREATE TABLE t_category
|
||
(
|
||
-- id:对应 MySQL 的 bigint(20) unsigned NOT NULL AUTO_INCREMENT
|
||
id BIGSERIAL PRIMARY KEY,
|
||
|
||
-- 分类名称:VARCHAR(60) NOT NULL DEFAULT '',同时是 UNIQUE 约束
|
||
"name" VARCHAR(60) NOT NULL DEFAULT '',
|
||
|
||
-- 创建时间
|
||
create_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW(),
|
||
|
||
-- 最后一次更新时间
|
||
update_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW(),
|
||
|
||
-- 逻辑删除标志位:tinyint(2) NOT NULL DEFAULT '0',改为 BOOLEAN
|
||
is_deleted BOOLEAN NOT NULL DEFAULT FALSE,
|
||
|
||
-- UNIQUE KEY uk_name (`name`)
|
||
CONSTRAINT uk_name UNIQUE ("name")
|
||
);
|
||
|
||
-- 添加非唯一索引(对应 MySQL 的 KEY `idx_create_time`)
|
||
CREATE INDEX idx_create_time ON t_category (create_time);
|
||
|
||
-- 可选:添加注释
|
||
COMMENT ON TABLE t_category IS '文章分类表';
|
||
COMMENT ON COLUMN t_category.id IS '分类id';
|
||
COMMENT ON COLUMN t_category.name IS '分类名称';
|
||
COMMENT ON COLUMN t_category.create_time IS '创建时间';
|
||
COMMENT ON COLUMN t_category.update_time IS '最后一次更新时间';
|
||
COMMENT ON COLUMN t_category.is_deleted IS '逻辑删除标志位:FALSE:未删除 TRUE:已删除';
|
||
-- 为 t_category 表创建触发器
|
||
CREATE TRIGGER set_t_category_update_time
|
||
BEFORE UPDATE
|
||
ON t_category
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION set_update_time();
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
-- 1. 创建表结构
|
||
CREATE TABLE t_tag
|
||
(
|
||
-- id: 使用 BIG SERIAL,自动创建序列,性能优异
|
||
id BIGSERIAL PRIMARY KEY,
|
||
|
||
-- name: 保持 VARCHAR(60),但在 PG 中 TEXT 和 VARCHAR 性能一样,
|
||
-- 这里为了保留原表 "60字符限制" 的业务逻辑,继续使用 VARCHAR(60)
|
||
name VARCHAR(60) NOT NULL DEFAULT '',
|
||
|
||
-- create_time: 使用带时区的时间戳,更标准严谨
|
||
create_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
||
-- update_time: 同上
|
||
update_time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
||
-- is_deleted: 使用原生 BOOLEAN 类型,存储效率高且语义明确
|
||
is_deleted BOOLEAN NOT NULL DEFAULT FALSE,
|
||
|
||
-- 约束:显式命名约束,方便后续维护(如报错时能看到具体约束名)
|
||
CONSTRAINT uk_tag_name UNIQUE (name)
|
||
);
|
||
|
||
-- 2. 创建普通索引
|
||
-- 对应 MySQL 的 KEY `idx_create_time`
|
||
CREATE INDEX idx_tag_create_time ON t_tag (create_time);
|
||
|
||
-- 3. 添加注释 (PostgreSQL 标准方式)
|
||
COMMENT ON TABLE t_tag IS '文章标签表';
|
||
COMMENT ON COLUMN t_tag.id IS '标签id';
|
||
COMMENT ON COLUMN t_tag.name IS '标签名称';
|
||
COMMENT ON COLUMN t_tag.create_time IS '创建时间';
|
||
COMMENT ON COLUMN t_tag.update_time IS '最后一次更新时间';
|
||
COMMENT ON COLUMN t_tag.is_deleted IS '逻辑删除标志位:FALSE:未删除 TRUE:已删除';
|
||
|
||
-- 4. 应用自动更新时间戳触发器 (体现 PostgreSQL 强大的过程语言优势)
|
||
-- 前提:您之前已经执行过 CREATE FUNCTION set_update_time() ...
|
||
CREATE TRIGGER set_t_tag_update_time
|
||
BEFORE UPDATE
|
||
ON t_tag
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION set_update_time();
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
-- ====================================================================================================================
|
||
CREATE TABLE t_blog_settings
|
||
(
|
||
-- id: 使用 BIGSERIAL 自动管理序列
|
||
id BIGSERIAL PRIMARY KEY,
|
||
|
||
-- logo: 图片路径可能很长,使用 TEXT 替代 VARCHAR(120),无性能损耗
|
||
logo TEXT NOT NULL DEFAULT '',
|
||
|
||
-- name: 博客名称通常较短,保留 VARCHAR 限制也是一种合理的业务约束
|
||
name VARCHAR(60) NOT NULL DEFAULT '',
|
||
|
||
-- author: 作者名同上
|
||
author VARCHAR(20) NOT NULL DEFAULT '',
|
||
|
||
-- introduction: 介绍语可能会变长,使用 TEXT 更灵活
|
||
introduction TEXT NOT NULL DEFAULT '',
|
||
|
||
-- avatar: 头像路径,使用 TEXT
|
||
avatar TEXT NOT NULL DEFAULT '',
|
||
|
||
-- 下面的主页链接:原 MySQL 定义 varchar(60) 风险很高,
|
||
-- 现在的 URL 很容易超过 60 字符,PG 使用 TEXT 完美解决
|
||
github_homepage TEXT NOT NULL DEFAULT '',
|
||
csdn_homepage TEXT NOT NULL DEFAULT '',
|
||
gitee_homepage TEXT NOT NULL DEFAULT '',
|
||
zhihu_homepage TEXT NOT NULL DEFAULT ''
|
||
);
|
||
|
||
-- 添加注释
|
||
COMMENT ON TABLE t_blog_settings IS '博客设置表';
|
||
COMMENT ON COLUMN t_blog_settings.id IS 'id';
|
||
COMMENT ON COLUMN t_blog_settings.logo IS '博客Logo';
|
||
COMMENT ON COLUMN t_blog_settings.name IS '博客名称';
|
||
COMMENT ON COLUMN t_blog_settings.author IS '作者名';
|
||
COMMENT ON COLUMN t_blog_settings.introduction IS '介绍语';
|
||
COMMENT ON COLUMN t_blog_settings.avatar IS '作者头像';
|
||
COMMENT ON COLUMN t_blog_settings.github_homepage IS 'GitHub 主页访问地址';
|
||
COMMENT ON COLUMN t_blog_settings.csdn_homepage IS 'CSDN 主页访问地址';
|
||
COMMENT ON COLUMN t_blog_settings.gitee_homepage IS 'Gitee 主页访问地址';
|
||
COMMENT ON COLUMN t_blog_settings.zhihu_homepage IS '知乎主页访问地址';
|
||
-- ====================================================================================================================
|
||
-- ==================================================================================================================== |