-- 切换到目标数据库 \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 "user_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 "user_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; -- 若视图存在,先删除(避免字段名冲突) IF view_exists THEN DROP VIEW user_info_view; RAISE NOTICE '已删除旧视图 user_info_view'; END IF; -- 创建或更新视图 CREATE OR REPLACE VIEW user_info_view AS SELECT u.id AS user_id, ua.account AS account, up.password AS 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 $$;