postgres讲义05_创建postgres表空间

PostgreSQL中表空间实际上就是给表指定一个存储目录

表空间的用途

1,如果初始化集簇所在的分区或者卷用光了空间,表空间可以被创建在一个不同的分区上,重新配置。

2,根据数据库对象的使用模式来优化性能。

例如,一个很频繁使用的索引可以被放在非常快并且非常可靠的磁盘上(如一种非常贵的固态设备)。

表空间跟数据库关系

a-在Oracle数据库中;一个表空间只属于一个数据库使用;而一个数据库可以拥有多个表空间。属于"一对多"的关系

b-在PostgreSQL集群中;一个表空间可以让多个数据库使用;而一个数据库可以使用多个表空间。属于"多对多"的关系

系统自带表空间

a-表空间pg_default是用来存储系统目录对象、用户表、用户表index、和临时表、临时表index、内部临时表的默认空间。对应存储目录$PADATA/base/

postgres讲义05_创建postgres表空间

b-表空间pg_global用来存放系统字典表;对应存储目录$PADATA/global/

postgres讲义05_创建postgres表空间

创建表空间

创建表空间必须首先建空目录,

新建文件目录: D:\PostgreSQL\9.3\data\TestDbs1

postgres讲义05_创建postgres表空间

创建方式一:

可以通过pgAdmin控制台的界面来创建表空间

postgres讲义05_创建postgres表空间

配置表空间名称

postgres讲义05_创建postgres表空间

配置表空间位置

postgres讲义05_创建postgres表空间

点击OK,创建成功

查看下刚刚创建的表空间的信息,如下:

postgres讲义05_创建postgres表空间

创建方式二:

通过psql命令行创建表空间

postgres=#  CREATE TABLESPACE "TestDBs2"

  OWNER postgres

  LOCATION E'D:\\PostgreSQL\\9.3\\data\\TestDbs2';

 

给表空间分配权限

表空间的创建必须作为一个数据库超级用户完成,但在创建完之后,可以允许普通数据库用户来使用。这样需给数据库普通用户授予表空间上的CREATE权限

postgres讲义05_创建postgres表空间

 

为数据库指定默认表空间

ALTER DATABASE TestDB1 SET TABLESPACE  tsp1;