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相关知识概念的更多相关文章
- 常用SQL操作(MySQL或PostgreSQL)与相关数据库概念
本文对常用数据库操作及相关基本概念进行总结:MySQL和PostgreSQL对SQL的支持有所不同,大部分SQL操作还是一样的. 选择要用的数据库(MySQL):use database_name; ...
- Golang(十)TLS 相关知识(一)基本概念原理
0. 前言 最近参与一个基于 BitTorrent 协议的 Docker 镜像分发加速插件的开发,主要参与补充 https 协议 学习了 TLS 相关知识,下面对之前的学习做一下简单总结 参考文献:T ...
- 【Python五篇慢慢弹(5)】类的继承案例解析,python相关知识延伸
类的继承案例解析,python相关知识延伸 作者:白宁超 2016年10月10日22:36:57 摘要:继<快速上手学python>一文之后,笔者又将python官方文档认真学习下.官方给 ...
- listener监听器的相关知识
从别人的博客上我学习了listener的相关知识现在分享给大家 1.概念: 监听器就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上 ...
- 【转】java NIO 相关知识
原文地址:http://www.iteye.com/magazines/132-Java-NIO Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的 ...
- Java 容器相关知识全面总结
Java实用类库提供了一套相当完整的容器来帮助我们解决很多具体问题.因为我本身是一名Android开发者,包括我在内很多安卓开发,最拿手的就是ListView(RecycleView)+BaseAda ...
- HTML入门基础教程相关知识
HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...
- 《Python网络编程》学习笔记--从例子中收获的计算机网络相关知识
从之前笔记的四个程序中(http://www.cnblogs.com/take-fetter/p/8278864.html),我们可以看出分别使用了谷歌地理编码API(对URL表示地理信息查询和如何获 ...
- python实现单例模式的三种方式及相关知识解释
python实现单例模式的三种方式及相关知识解释 模块模式 装饰器模式 父类重写new继承 单例模式作为最常用的设计模式,在面试中很可能遇到要求手写.从最近的学习python的经验而言,singlet ...
随机推荐
- Android Menu的基本用法
使用xml定义Menu 菜单资源文件必须放在res/menu目录中.菜单资源文件必须使用<menu>标签作为根节点.除了<menu>标签外,还有另外两个标签用于设置菜单项和分组 ...
- Servlet(2):通过servletContext对象实现数据共享
一,ServletContext介绍 web容器在启动时,它会为每一个web应用程序都创建一个ServletContext对象,它代表当前web应用 多个Servlet通过ServletContext ...
- 【编程思想】【设计模式】【行为模式Behavioral】Publish_Subscribe
Python版 https://github.com/faif/python-patterns/blob/master/behavioral/publish_subscribe.py #!/usr/b ...
- 什么是javaScript闭包
闭包是与函数有着紧密的关系,它是函数的代码在运行过程中的一个动态环境,是一个运行期的概念. 所谓闭包,是指词法表示包括不必计算的变量的函数.也就是说,该函数能够使用函数外定义的变量. 在程序语言中,所 ...
- 【Java】【学习】【监听器】Listener的学习的案例(窗体程序)
JavaWeb 监听器listener 学习与简单应用 Java窗体程序使用监听器 效果:点击按钮,控制台出现文字 代码如下 import javax.swing.*; import java.awt ...
- 网络访问控制列表ACL(读懂这篇就基本够了,后面有配置案例)
一.访问控制列表是什么? 访问控制列表(ACL)是一种基于包过滤的访问控制技术,它可以根据设定的条件对接口上的数据包进行过滤,允许其通过或丢弃.访问控制列表被广泛地应用于路由器和三层交换机,借助于访问 ...
- [BUUCTF]PWN——picoctf_2018_buffer overflow 1/2
picoctf_2018_buffer overflow 1 附件 步骤: 例行检查,32位程序,没开保护 本地运行一下程序,看看程序大概的执行情况 32位ida载入,习惯性的检查程序里的字符串,发现 ...
- 为什么没有APS排产的MES是没有灵魂的?
ERP系统在于对整个企业与集团企业间的全面管控,APS系统是生产规划及排程系统,MES系统重点在于车间现场的管理,下面用最简单方式讲讲ERP系统.APS系统和MES系统之间的区别与联系. 没有APS计 ...
- 材料资源和成本资源(Project)
<Project2016 企业项目管理实践>张会斌 董方好 编著 第二种资源就是[材料资源]啦~ 拿到资源第一件事就是输入基本信息,这个,不复读了,复读得我自己都嫌烦.好吧,还得说明一下, ...
- 【LeetCode】435. Non-overlapping Intervals 解题报告(Python)
[LeetCode]435. Non-overlapping Intervals 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemi ...