下面是一个完整的 PostgreSQL 示例,展示了如何创建数据库、用户、模式(schema)、表、视图、函数,并赋予用户权限以及删除权限的步骤。假设你已经安装并配置了 PostgreSQL。
首先,登录到 PostgreSQL 的命令行客户端(psql),然后执行以下命令创建数据库:
-- 创建数据库
CREATE DATABASE mydb;
-- 创建用户
CREATE USER myuser WITH PASSWORD 'mypassword';
-- 连接到数据库 mydb
\c mydb
-- 创建 schema
CREATE SCHEMA myschema;
-- 创建表
CREATE TABLE myschema.mytable (
id SERIAL PRIMARY KEY,
name VARCHAR(50),
age INT
);
-- 创建视图
CREATE VIEW myschema.myview AS
SELECT name, age FROM myschema.mytable;
-- 创建函数
CREATE OR REPLACE FUNCTION myschema.get_age(name VARCHAR)
RETURNS INT AS $$
BEGIN
RETURN (SELECT age FROM myschema.mytable WHERE mytable.name = name);
END;
$$ LANGUAGE plpgsql;
-- 赋予用户权限
GRANT CONNECT ON DATABASE mydb TO myuser;
GRANT USAGE ON SCHEMA myschema TO myuser;
GRANT SELECT, INSERT, UPDATE, DELETE ON ALL TABLES IN SCHEMA myschema TO myuser;
GRANT SELECT ON ALL SEQUENCES IN SCHEMA myschema TO myuser;
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA myschema TO myuser;
-- 删除用户权限
REVOKE ALL ON DATABASE mydb FROM myuser;
REVOKE ALL ON SCHEMA myschema FROM myuser;
REVOKE ALL ON ALL TABLES IN SCHEMA myschema FROM myuser;
REVOKE ALL ON ALL SEQUENCES IN SCHEMA myschema FROM myuser;
REVOKE ALL ON ALL FUNCTIONS IN SCHEMA myschema FROM myuser;