98 lines
3.2 KiB
SQL
98 lines
3.2 KiB
SQL
-- 切换到目标数据库
|
||
\c postgres;
|
||
|
||
DO $$
|
||
BEGIN
|
||
IF NOT EXISTS (SELECT 1 FROM information_schema.tables WHERE table_name = 'user') THEN
|
||
CREATE TABLE "user" ( -- user是关键字,用双引号包裹
|
||
id UUID DEFAULT gen_random_uuid_v7() PRIMARY KEY NOT NULL,
|
||
deleted BOOLEAN NOT NULL DEFAULT FALSE,
|
||
created_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updated_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||
);
|
||
CREATE TRIGGER update_user_updated_at
|
||
BEFORE UPDATE ON "user"
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_data_modified_column();
|
||
|
||
RAISE NOTICE 'created user table and trigger';
|
||
ELSE
|
||
RAISE NOTICE 'user table already exists';
|
||
END IF;
|
||
|
||
IF NOT EXISTS (SELECT 1 FROM information_schema.tables WHERE table_name = 'user_account') THEN
|
||
CREATE TABLE user_account (
|
||
id UUID DEFAULT gen_random_uuid_v7() PRIMARY KEY NOT NULL,
|
||
user_id UUID NOT NULL,
|
||
account VARCHAR NOT NULL,
|
||
deleted BOOLEAN NOT NULL DEFAULT FALSE,
|
||
created_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updated_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||
);
|
||
CREATE TRIGGER update_user_account_updated_at
|
||
BEFORE UPDATE ON "account"
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_data_modified_column();
|
||
|
||
RAISE NOTICE 'created user_account table and trigger';
|
||
ELSE
|
||
RAISE NOTICE 'user_account table already exists';
|
||
END IF;
|
||
|
||
IF NOT EXISTS (SELECT 1 FROM information_schema.tables WHERE table_name = 'user_password') THEN
|
||
CREATE TABLE user_password (
|
||
id UUID DEFAULT gen_random_uuid_v7() PRIMARY KEY NOT NULL,
|
||
user_id UUID NOT NULL,
|
||
password VARCHAR NOT NULL,
|
||
deleted BOOLEAN NOT NULL DEFAULT FALSE,
|
||
created_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
updated_at TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||
);
|
||
CREATE TRIGGER update_user_password_updated_at
|
||
BEFORE UPDATE ON "password"
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_data_modified_column();
|
||
|
||
RAISE NOTICE 'created user_password table and trigger';
|
||
ELSE
|
||
RAISE NOTICE 'user_password table already exists';
|
||
END IF;
|
||
END $$;
|
||
|
||
DO $$
|
||
DECLARE
|
||
view_exists BOOLEAN;
|
||
BEGIN
|
||
-- 检查视图是否已存在
|
||
SELECT EXISTS (
|
||
SELECT 1 FROM information_schema.views
|
||
WHERE table_name = 'user_info_view'
|
||
) INTO view_exists;
|
||
|
||
-- 创建或更新视图
|
||
CREATE OR REPLACE VIEW user_info_view AS
|
||
SELECT
|
||
u.id AS user_id,
|
||
ua.account AS user_account,
|
||
up.password AS user_password,
|
||
u.deleted AS deleted
|
||
FROM
|
||
"user" u
|
||
JOIN
|
||
user_account ua ON u.id = ua.user_id
|
||
JOIN
|
||
user_password up ON u.id = up.user_id
|
||
WHERE
|
||
u.deleted = FALSE;
|
||
|
||
-- 根据视图是否已存在输出不同提示
|
||
IF view_exists THEN
|
||
RAISE NOTICE '视图 user_info_view 已更新';
|
||
ELSE
|
||
RAISE NOTICE '视图 user_info_view 已创建';
|
||
END IF;
|
||
EXCEPTION
|
||
WHEN OTHERS THEN
|
||
RAISE NOTICE '处理视图时发生错误: %', SQLERRM;
|
||
END $$;
|