【PostgreSQL】系列之 一 schema详解(二)

🍁 博主 "开着拖拉机回家"带您 Go to New World.✨🍁

🦄 个人主页------🎐开着拖拉机回家_Linux,Java基础学习,大数据运维-CSDN博客 🎐✨🍁

🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🍁🐥


目录

[🍁 博主 "开着拖拉机回家"带您 Go to New World.✨🍁](#🍁 博主 "开着拖拉机回家"带您 Go to New World.✨🍁)

一、概述

二、创建schema

三、访问schema中的对象

四、schema和授权

五、schema和备份


一、概述


在SQL环境下,schema就是数据库对象的集合,所谓的数据库对象也就是常说的表,索引,视图,存储过程等。在schema之上的,就是数据库的实例,也就是通常create databases获得的东西。也就是说一个schema 实例 可以有多个schema, 可以给不同的用户创建不同的schema,并且他们都是在同一数据库实例下面。

PostgreSQL schema是其独有的一个强大的功能,它可以使一个单独的数据库实例中包含多个独立的、命名空间互相隔离的区域。这个功能让多个应用程序可以在同一个数据库实例中运行,而不会相互干扰。

schema是由一组表、视图、序列、函数、索引等对象组成的,这些对象也被称为schema中的命名空间。


二、创建schema


在postgresql中,需要使用CREATE SCHEMA命令来创建一个新的schema。语法如下:

bash 复制代码
CREATE SCHEMA schema_name;

其中,schema_name为指定的schema名称。如果要在query中使用新创建的schema,必须先将当前查询所在的schema切换至新的schema,通过以下语句实现:

bash 复制代码
SET search_path TO schema_name;

此时查询将默认从新的schema中获取数据。


三、访问schema中的对象


通过schema的隔离机制,可以给应用程序提供'私有'的命名空间。如果schema中有同名的表或其他对象,postgresql会优先选择当前schema中自己的对象。在sql中可以通过以下语法访问特定schema的对象:

bash 复制代码
schema_name.table_name

例如访问一个名为'students'的表:

bash 复制代码
SELECT * FROM ambari_test.users;

我们可以看到 只要切换到对应的 schema ,schema 加与不加 都可以 访问表,

在ambari_test 的 schema 访问public的 stu表 会报错,这个时候我们需要加上 schema ,也就是说 跨 schema 访问 需要显示加上 schema 。


四、schema和授权


在postgresql中,可以使用GRANT和REVOKE命令控制用户对schema中的对象的访问权限。授权用法如下:

cs 复制代码
GRANT privilege ON SCHEMA schema_name TO role_name;

其中,privilege可以是SELECT、INSERT、UPDATE、DELETE、USAGE等权限,role_name是指授权对象。例如,授权用户'admin'可以访问'students'表:

cs 复制代码
# 创建名为 zhang 的用户
create user zhang with password '123456';

# 授予使用权限
grant usage on schema kangll_schema  to zhang;

# 给zhang用户 授予kangll_schema 所有表的查询权限
grant select  on all tables in schema kangll_schema to zhang;

因为配置文件中默认的搜索路径包括公共schema,postgres用户(数据超级用户)对所有schema都有访问权限,授权使用 管理员完成。

USAGE和SELECT区别

USAGE 权限只让角色能够访问 SCHEMA 中的数据类型、操作符、函数等其他数据库对象,但是不包含对 SCHEMA 中的表的访问权。

如果没有为表(例如:api.todos)授权 SELECT 权限,即使已授权 SCHEMA 的 USAGE 权限,角色仍然无法读取该表中的数据。为了允许一个角色执行 SELECT 查询并获取某个表中的数据,你需要为该角色分别授权 SCHEMA 的 USAGE 权限和表的 SELECT 权限。


五、schema和备份


postgresql数据库备份时,可以选择备份指定的schema,或者备份整个数据库。备份指定schema需要用到命令的--schema=schema_name选项。例如备份名称为'my_backup'的'my_schema' schema:

cs 复制代码
pg_dump -h localhost -p 5432 -U postgres -F t -b -v --schema=kangll_schema -f ./my_backup.tar.gz kangll_test

注意,该命令只会备份'kangll_schema' schema中的对象。如下是备份完成后 tar包内容:


PostgreSQL schema详解_笔记大全_设计学院

原文链接:Schema是什么_数据库中的schema是什么意思_Loobeeke的博客-CSDN博客

相关推荐
万邦科技Lafite8 小时前
实战演练:利用京东API一键抓取商品详情
数据库·redis·python·缓存·开放api·淘宝开放平台
LIUAWEIO8 小时前
接口 data 满屏反斜杠,怎么展开?
java·开发语言·数据库·json在线解析·data是字符串·json转义·二次json
沪漂阿龙9 小时前
面试题详解:大模型设计沙箱全攻略——LLM Sandbox、Agent 工具执行、代码沙箱、安全隔离、权限控制与工程落地
网络·数据库·人工智能·安全
IT策士9 小时前
Django 从 0 到 1 打造完整电商平台:Admin 后台管理与数据初始化
数据库·django·sqlite
Wait....9 小时前
死锁的知识总结
数据库·mysql
橙子圆12310 小时前
Redis知识7之主从复制
数据库·redis·缓存
IndulgeCui10 小时前
Kingbase基于UOS Server 20 三种详细安装部署方式
数据库
DianSan_ERP10 小时前
自研电商架构:一套API安全对接60+平台
大数据·运维·数据库·人工智能·安全·架构
海南java第二人10 小时前
ClickHouse 自然语言统一查询:让数据对话成为现实
网络·数据库·clickhouse
逻辑羊驼10 小时前
VSCODE 连接 MySQL 数据库并执行当地SQL文件
数据库·mysql