表空间管理
操作场景
云数据库RDS提供基于root用户的PostgreSQL表空间管理方案。
创建表空间
- 以root用户连接数据库,并创建表空间。
     
     # psql --host=<RDS_ADDRESS> --port=<DB_PORT> --dbname=<DB_NAME> --username=root -c "select control_tablespace ('create', '<TABLESPACE_NAME>');" 表1 参数说明 参数 说明 RDS_ADDRESS RDS实例的IP地址。 DB_PORT RDS数据库实例的端口。 DB_NAME 数据库名称。 TABLESPACE_NAME 表空间名称。 
- 根据提示输入root用户密码。
     
     登录至数据库“my_db”中并创建表空间“tbspc1”示例如下: # psql --host=192.168.6.141 --port=5432 --dbname=my_db --username=root -c "select control_tablespace('create', 'tbspc1');" Password for user root: control_tablespace ------------------------------ create tablespace tbspc1 successfully. (1 row)如创建不成功,详细信息请查看该实例错误日志。   为考虑性能,用户最多可创建100个表空间。 
授权表空间使用权限
- 以root用户连接数据库,并授权表空间使用权限给指定用户。
     
     # psql --host=<RDS_ADDRESS> --port=<DB_PORT> --dbname=<DB_NAME> --username=root -c "select control_tablespace ('alter', '<TABLESPACE_NAME>', '<USER_NAME>');" 表2 参数说明 参数 说明 RDS_ADDRESS RDS实例的IP地址。 DB_PORT RDS数据库实例的端口。 DB_NAME 数据库名称。 TABLESPACE_NAME 表空间名称。 USER_NAME 表空间的用户名。 
- 根据提示输入root用户密码。
     
     登录至数据库“my_db”中并授权表空间“tbspc1”使用权限示例如下: # psql --host=192.168.6.141 --port=5432 --dbname=my_db --username=root -c "select control_tablespace('alter', 'tbspc1', 'user1');" Password for user root: control_tablespace ---------------------------- alter tablespace tbspc1 successfully. (1 row)如授权不成功,详细信息请查看该实例错误日志。 
删除表空间
- 以root用户连接数据库,并删除表空间。
     
     # psql --host=<RDS_ADDRESS> --port=<DB_PORT> --username=root --dbname=<DB_NAME> -c "select control_tablespace('drop', '<TABLESPACE _NAME>');" 表3 参数说明 参数 说明 RDS_ADDRESS RDS实例的IP地址。 DB_PORT RDS数据库实例的端口。 DB_NAME 数据库名称。 TABLESPACE_NAME 表空间名称。 
- 根据提示输入root用户密码。
     
     示例如下: # psql --host=192.168.6.141 --port=8635 --dbname=my_db --username=root -c "select control_tablespace('drop', 'tbspc1');" Password for user root: control_tablespace ---------------------------- drop tablespace tbspc1 successfully. (1 row)删除表空间之前请确认该表空间已为空。如删除不成功,详细信息请查看该实例错误日志。 
 
    