30 lines
993 B
PL/PgSQL
30 lines
993 B
PL/PgSQL
-- 切换到目标数据库
|
||
\c postgres;
|
||
|
||
CREATE OR REPLACE FUNCTION update_country_modified_column()
|
||
RETURNS TRIGGER AS $$
|
||
BEGIN
|
||
NEW.updated_at = CURRENT_TIMESTAMP;
|
||
RETURN NEW;
|
||
END;
|
||
$$ LANGUAGE plpgsql VOLATILE;
|
||
|
||
DO $$
|
||
BEGIN
|
||
IF NOT EXISTS (SELECT 1 FROM information_schema.tables WHERE table_name = 'country') THEN
|
||
CREATE TABLE "country" ( -- country是关键字,用双引号包裹
|
||
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_country_updated_at
|
||
BEFORE UPDATE ON "country"
|
||
FOR EACH ROW
|
||
EXECUTE FUNCTION update_country_modified_column();
|
||
|
||
RAISE NOTICE 'Created country table and trigger';
|
||
ELSE
|
||
RAISE NOTICE 'country table already exists';
|
||
END IF;
|
||
END $$; |