PostgreSQL相关知识概念
本文主要介绍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相关知识概念相关推荐
- 路由相关知识,静态路由、默认路由、浮动路由的概念以及基本设置
路由相关知识,静态路由.默认路由.浮动路由的概念以及基本设置 选取最佳路由时的标准 路由表 路由表的形成 静态路由概念 静态路由的优点和缺点 默认路由 浮动路由 路由协议分类 静态路由.默认路由.浮动 ...
- Vue2简单使用及相关基础知识概念(适合小白入门,看完就能上手)
Vue2相关知识 一.概念 1.前端模式 2.MVVM模式 2.1 概念 2.2 优点 (1)低耦合 (2)可复用 (3)独立开发 (4)可测试 3.Vue 3.1 概念 3.2 优点 3.3 参考网 ...
- Redux相关知识(什么是redux、redux的工作原理、redux的核心概念、redux的基本使用)(十一)
系列文章目录 第一章:React基础知识(React基本使用.JSX语法.React模块化与组件化)(一) 第二章:React基础知识(组件实例三大核心属性state.props.refs)(二) 第 ...
- 视频压缩算法的相关知识
视频压缩算法的相关知识 MPEG-1 MPEG 视频压缩编码后包括三种元素:I帧(I-frames).P帧(P-frames)和B帧(B-frames).在MPEG编码的过程中,部分视频帧序列压缩成为 ...
- WiFi相关基础概念
转自:https://blog.csdn.net/lbaihao/article/details/73250798 一.WiFi相关基础概念 1.什么是wifi 我们看一下百度百科是如何定义的: Wi ...
- Docker容器原理及相关知识
Docker容器原理及相关知识 一.Docker容器介绍 1.容器概念 2.Docker介绍 3.Dcker的特点 二.Docker的体系架构 三.相关术语介绍 1.Docker 客户端 2.Dock ...
- 中级统计师基础知识中计算机,【2014年中级统计师《统计基础理论及相关知识》预习:计算机操作系统】- 环球网校...
[摘要]2014年中级统计师<统计基础理论及相关知识>预习:计算机操作系统 2014年统计师考试备考已经开始,为了帮助参加2014年中级统计师考试考生提高备考效果,环球网校为大家整理了中级 ...
- Mysql数据库(四)——mysql索引相关知识
Mysql数据库(四)--mysql索引相关知识 一.索引的概念 二.索引的优缺点 1.优点 2.缺点 三.创建索引的原则 四.索引的分类和创建方法 1.普通索引 ①.直接创建索引 ②.修改表方式创建 ...
- 单片机小白学步系列(十) 单片机程序下载相关知识
注:本篇在写<单片机入门指南系列>之前就已经写过,现在发现这篇比较合理的位置,应该是放在<单片机入门指南系列(六) 单片机最小系统--麻雀虽小,五脏俱全>之后的,但是由于之前考 ...
最新文章
- qt chart 如何使网格填满整个窗口_Qt实现截屏的关键函数
- 计算机隐藏用户设置,在开始屏幕(欢迎屏幕、控制面板的用户账户设置)上隐藏用户账户和开机自动登录某个账户...
- Oracle常用监控SQL
- linxu安装OSX
- scikit-learn工具包使用建议(转)
- CGContextAddLines和CGContextAddLineToPoint在线条半透明时候的区别
- SQL Server 数据库部分常用语句小结
- Swing应用程序中的JavaFX 8 DatePicker
- 【AI视野·今日CV 计算机视觉论文速览 第162期】Fri, 27 Sep 2019
- 7 Managing Users and Securing the Database
- linux 路由添加
- 官方实力榜:绿军居首黄蜂第二 火箭小降雄鹿飙升
- 电子邮件是html文件吗,如何在电子邮件正文中嵌入HTML文件
- oracle数据库greatest函数,ORACLE函数之GREATEST函数详解范例
- yaaw 错误 “No such method: aria2.addTorrent”的解决办法
- automation 服务器不能创建对象解决办法
- html文档半结构化数据,什么是半结构化数据?
- ATTCK框架以及使用场景
- 光刻胶剥离和光掩模清洁的工艺顺序
- 【视觉定位UV】日志分析之Mark点详解