定义一个新的表空间
CREATE TABLESPACE tablespace_name [OWNER username]
FILESPACE filespace_name
[ WITH UFSPATH ufs_path]
CREATE TABLESPACE 为用户的 HashData 数据库系统注册一个新的表空间。该表空间的名字必须和系统中已存在其他任何表空间不同名。
一个表空间允许超级用户在文件系统上定义可选择的位置,该位置中的驻有包含数据库对象(表和索引)在内的数据文件。
有适当权利的用户可以传递一个表空间名到 CREATE DATABASE,CREATE TABLE,或 CREATE INDEX 中来使这些对象的数据文件存储在指定的表空间中。
在 HashData 数据库中,必须对 Master、每个 Segment,每个 Segment 镜像都有一个定义好的文件系统,为的就是让表空间在整个 HashData 系统中有位置来存储它的对象。该文件系统位置的集合定义在文件空间对象中。在用户创建一个表空间之前,必须定义一个文件空间。
HashData数据库同时扩展了基于Alluxio的tablespace,创建在dfs_system这个filespace下的tablespace将会通过访问Alluxio来进行文件操作。同时用户需要指定UFSPATH来对Alluxio加载的底层文件系统进行配置。
tablespacename
要创建表空间名字,该名字不能以 pg_
或 gp_
开头,因为这些名字是为系统表空间预留的。
OWNER username
拥有该表空间用户的名字。如果省略,默认为执行该命令的用户。只有超级用户可以创建表空间,但是他们能分配表空间的所属权给非超级用户。
FILESPACE
HashData 数据库表空间的名字,该表空间由 gpfilespace 管理实用程序所定义。
UFSPATH
基于Alluxio的表空间所对应的底层文件系统配置信息。
用户必须首先创建一个由表空间使用的文件空间。
表空间仅在支持符号链接的系统上支持。
CREATE TABLESPACE 不能在事务块中执行。
通过指定相应的要用文件空间,创建一个新的表空间。
CREATE TABLESPACE mytblspace FILESPACE myfilespace;
通过指定UFSPATH来创建青云对象存储表空间。注意这里的filespace需固定填写dfs_system。
Before 2.3.0
CREATE TABLESPACE mytblspace FILESPACE dfs_system WITH UFSPATH "qingstore://bucket-name/path";
After 2.5.1
CREATE TABLESPACE mytblspace FILESPACE dfs_system UFSPATH='qingstor://bucket/folder' UFSINFO='access_key_id=myAccessKey secret_access_key=mySecretKey region=pek3a'
CREATE TABLESPACE 是 HashData 数据库扩展。
CREATE DATABASE, CREATE TABLE, CREATE INDEX, DROP TABLESPACE, ALTER TABLESPACE, gpfilespace
上级话题: SQL命令参考