本文主要介绍PostgreSQL数据库的一些重要知识点,
包括数据库、模式、表空间、用户/角色等概念和关系,
帮助用户理解PostgreSQL数据库的重要概念,
从而能够更好的使用PostgreSQL。

1.ROLE/USER区别

通常ROLE(角色)和USER(用户)是两个不同的概念,
但是在PostgreSQL里没有区分用户和角色,
这里容易和其他数据库的概念混淆,
在PostgreSQL两者区别仅在于用户比角色多了登陆权限。

下面分别是创建ROLE和USER的SQL:

CREATE ROLE kanon1 PASSWORD 'kanon1';
CREATE USER kanon2 PASSWORD 'kanon2';

创建完成后ROLE kanon1不能登陆,
但是USER kanon2能够登陆。

为ROLE kanon1增加LOGIN权限:

ALTER ROLE kanon1 LOGIN;

然后kanon1也能够登陆了。

CREATE USER除了默认具有LOGIN权限之外,
其他与CREATE ROLE是完全相同的。
下面两条SQL语句是等价的:

CREATE ROLE kanon PASSWORD 'kanon' LOGIN;
CREATE USER kanon PASSWORD 'kanon';

角色(用户)可以拥有全局数据库对象,
可以拥有数据库服务器全局范围内的权限,
用于对数据库所有的对象进行管理。
角色不特定于某个单独的数据库,
如果需要管理数据库系统则必须连接到一个数据库上。

2.DATABASE与SCHEMA的关系

SCHEMA(模式)是对DATABASE(数据库)逻辑分割,
SCHEMA可以理解为命名空间,
SCHEMA就是数据库对象的集合。
一个DATABASE至少有一个SCHEMA,
在创建DATABASE时,
自动创建一个默认SCHEMA public。
这个DATABASE创建的所有对象(表、函数、视图、索引、序列等),
如果没有指定SCHEMA,
默认都是属于public。

用户登录到PostgreSQL,连接到一个数据库后,
由于一个DATABASE可以有多个SCHEMA,
需要通过DATABASE的search_path来确定SCHEMA的搜索顺序,
可以通过命令SHOW查看具体的顺序,
也可以通过命令SET来设置顺序。
查看当前数据库搜索路径:

SHOW search_path;

设置新的搜索路径:

SET search_path TO myschema,public;

官方建议
在管理员创建一个DATABASE后,
应该为所有可以连接到该DATABASE的用户,
分别创建一个与用户名相同的SCHEMA,
然后将search_path设置为"$user",
这样当某个用户连接上来后,
默认使用的是与之同名的SCHEMA,
这是一个好的设计架构。

3.为DATABASE对象指定SCHEMA

数据库中一个对象的完整名称为SCHEMA.object,
而不是USER.object。
如果在操作对象时不指定SCHEMA,
则使用登陆用户的默认SCHEMA。

比如查询一个表时,
没有指明该表所属的SCHEMA,
系统自动在表上加上默认的SCHEMA名。
查询freeoa用户的emp表:

select * from emp;

假设freeoa用户默认的SCHEMA为freeoa,
则实际上SQL语句的完整写法:

select * from freeoa.emp;

创建schema kanon,属主为kanon:

CREATE SCHEMA kanon OWNER kanon;

创建表test,指定属于schema kanon:

CREATE TABLE kanon.test (id integer not null);

同一个对象名可以在不同的SCHEMA里使用而不会导致冲突,
比如schema1和schema2都可以包含叫做test的表,
和DATABASE不同,SCHEMA不是严格分离的,
一个用户只要有权限,
可以访问一个DATABASE中的任意SCHEMA。

用户可以允许别人在自己的SCHEMA里创建对象,
需要赋予其他用户在该SCHEMA的CREATE权限。
默认每个人都在SCHEMA public上有CREATE权限,
所以连接到数据库上的用户都可以在public创建对象。
这个权限可以撤销:

REVOKE CREATE ON public FROM PUBLIC;

第一个public是SCHEMA,
第二个PUBLIC是指所有用户。

4.表空间

在PostgreSQL中,表空间是一个目录,
表空间是实际的数据存储的地方,
存储的是它所包含的数据库的各种物理文件。
一个数据库schema可能存在于多个表空间,
一个表空间也可以为多个schema服务。

创建数据库使用CREATE DATABASE dbname,
默认的数据库所有者是当前创建数据库的用户,
默认的表空间是系统的默认表空间pg_default。
在PostgreSQL中,数据库的创建是通过克隆数据库模板来实现的。
由于CREATE DATABASE dbname并没有指明数据库模板,
所以默认使用template1数据库当作克隆模板,
template1中的全部对象将被同步克隆到新的数据库中。
由于template1数据库的默认表空间是pg_default,
所以新的数据库也使用默认表空间是pg_default,
pg_default这个表空间是在数据库初始化时创建的。

创建数据库时指定数据库模板和表空间:

CREATE DATABASE dbname OWNER kanon TEMPLATE template1 TABLESPACE tablespacename;

表空间的作用:
通过使用表空间,管理员可以控制磁盘的布局。
表空间的最常用的作用是优化性能,
比如一个最常用的索引可以建立在非常快的硬盘上,
而不太常用的表可以建立在便宜的硬盘上,
比如用来存储用于进行归档文件的表。

PostgreSQL相关知识概念相关推荐

  1. 路由相关知识,静态路由、默认路由、浮动路由的概念以及基本设置

    路由相关知识,静态路由.默认路由.浮动路由的概念以及基本设置 选取最佳路由时的标准 路由表 路由表的形成 静态路由概念 静态路由的优点和缺点 默认路由 浮动路由 路由协议分类 静态路由.默认路由.浮动 ...

  2. Vue2简单使用及相关基础知识概念(适合小白入门,看完就能上手)

    Vue2相关知识 一.概念 1.前端模式 2.MVVM模式 2.1 概念 2.2 优点 (1)低耦合 (2)可复用 (3)独立开发 (4)可测试 3.Vue 3.1 概念 3.2 优点 3.3 参考网 ...

  3. Redux相关知识(什么是redux、redux的工作原理、redux的核心概念、redux的基本使用)(十一)

    系列文章目录 第一章:React基础知识(React基本使用.JSX语法.React模块化与组件化)(一) 第二章:React基础知识(组件实例三大核心属性state.props.refs)(二) 第 ...

  4. 视频压缩算法的相关知识

    视频压缩算法的相关知识 MPEG-1 MPEG 视频压缩编码后包括三种元素:I帧(I-frames).P帧(P-frames)和B帧(B-frames).在MPEG编码的过程中,部分视频帧序列压缩成为 ...

  5. WiFi相关基础概念

    转自:https://blog.csdn.net/lbaihao/article/details/73250798 一.WiFi相关基础概念 1.什么是wifi 我们看一下百度百科是如何定义的: Wi ...

  6. Docker容器原理及相关知识

    Docker容器原理及相关知识 一.Docker容器介绍 1.容器概念 2.Docker介绍 3.Dcker的特点 二.Docker的体系架构 三.相关术语介绍 1.Docker 客户端 2.Dock ...

  7. 中级统计师基础知识中计算机,【2014年中级统计师《统计基础理论及相关知识》预习:计算机操作系统】- 环球网校...

    [摘要]2014年中级统计师<统计基础理论及相关知识>预习:计算机操作系统 2014年统计师考试备考已经开始,为了帮助参加2014年中级统计师考试考生提高备考效果,环球网校为大家整理了中级 ...

  8. Mysql数据库(四)——mysql索引相关知识

    Mysql数据库(四)--mysql索引相关知识 一.索引的概念 二.索引的优缺点 1.优点 2.缺点 三.创建索引的原则 四.索引的分类和创建方法 1.普通索引 ①.直接创建索引 ②.修改表方式创建 ...

  9. 单片机小白学步系列(十) 单片机程序下载相关知识

    注:本篇在写<单片机入门指南系列>之前就已经写过,现在发现这篇比较合理的位置,应该是放在<单片机入门指南系列(六) 单片机最小系统--麻雀虽小,五脏俱全>之后的,但是由于之前考 ...

最新文章

  1. qt chart 如何使网格填满整个窗口_Qt实现截屏的关键函数
  2. 计算机隐藏用户设置,在开始屏幕(欢迎屏幕、控制面板的用户账户设置)上隐藏用户账户和开机自动登录某个账户...
  3. Oracle常用监控SQL
  4. linxu安装OSX
  5. scikit-learn工具包使用建议(转)
  6. CGContextAddLines和CGContextAddLineToPoint在线条半透明时候的区别
  7. SQL Server 数据库部分常用语句小结
  8. Swing应用程序中的JavaFX 8 DatePicker
  9. 【AI视野·今日CV 计算机视觉论文速览 第162期】Fri, 27 Sep 2019
  10. 7 Managing Users and Securing the Database
  11. linux 路由添加
  12. 官方实力榜:绿军居首黄蜂第二 火箭小降雄鹿飙升
  13. 电子邮件是html文件吗,如何在电子邮件正文中嵌入HTML文件
  14. oracle数据库greatest函数,ORACLE函数之GREATEST函数详解范例
  15. yaaw 错误 “No such method: aria2.addTorrent”的解决办法
  16. automation 服务器不能创建对象解决办法
  17. html文档半结构化数据,什么是半结构化数据?
  18. ATTCK框架以及使用场景
  19. 光刻胶剥离和光掩模清洁的工艺顺序
  20. 【视觉定位UV】日志分析之Mark点详解

热门文章

  1. Delphi Code Editor 之 几个特性
  2. python创建和删除文件
  3. python -sorted 学习
  4. 从RGB扫描图到数字化等高线矢量图
  5. 通过Intel XDK编写跨平台app(二)
  6. opengl 关于glewGetContext没有定义
  7. Cassandra数据读取机制
  8. Word 2007 发布测试
  9. 模式识别中的特征提取及其内在意义
  10. C++之char , signed char , unsigned char