PostgreSQL中表空间实际上就是给表指定一个存储目录。
表空间的用途
1,如果初始化集簇所在的分区或者卷用光了空间,表空间可以被创建在一个不同的分区上,重新配置。
2,根据数据库对象的使用模式来优化性能。
例如,一个很频繁使用的索引可以被放在非常快并且非常可靠的磁盘上(如一种非常贵的固态设备)。
表空间跟数据库关系
a-在Oracle数据库中;一个表空间只属于一个数据库使用;而一个数据库可以拥有多个表空间。属于"一对多"的关系
b-在PostgreSQL集群中;一个表空间可以让多个数据库使用;而一个数据库可以使用多个表空间。属于"多对多"的关系
系统自带表空间
a-表空间pg_default是用来存储系统目录对象、用户表、用户表index、和临时表、临时表index、内部临时表的默认空间。对应存储目录$PADATA/base/
b-表空间pg_global用来存放系统字典表;对应存储目录$PADATA/global/
创建表空间
创建表空间必须首先建空目录,
新建文件目录: D:\PostgreSQL\9.3\data\TestDbs1
创建方式一:
可以通过pgAdmin控制台的界面来创建表空间
配置表空间名称
配置表空间位置
点击OK,创建成功
查看下刚刚创建的表空间的信息,如下:
创建方式二:
通过psql命令行创建表空间
postgres=# CREATE TABLESPACE "TestDBs2"
OWNER postgres
LOCATION E'D:\\PostgreSQL\\9.3\\data\\TestDbs2';
给表空间分配权限
表空间的创建必须作为一个数据库超级用户完成,但在创建完之后,可以允许普通数据库用户来使用。这样需给数据库普通用户授予表空间上的CREATE权限。
为数据库指定默认表空间
ALTER DATABASE TestDB1 SET TABLESPACE tsp1;