在PostgreSQL中,表空间实际上是为表指定一个存储目录,这样方便我们把不同的表放在不同的存储介质或者文件系统中。在创建数据库、表、索引时都可以指定表空间。

1. 创建表空间

--表空间目录必须是系统中已存在的目录
test=# create tablespace tb_01 location '/opt/postgresql/data/pg_data';
CREATE TABLESPACE

2. 创建数据库,指定表空间

test=# create database test01 tablespace tb_01;
CREATE DATABASE

3. 修改数据库的表空间

test=# alter database test01 set tablespace tb_02;
ALTER DATABASE
--修改数据库的默认表空间后,数据库中表的表空间不会改变。

4. 建表时,指定表空间

test=# create table t1 (id int,note text) tablespace tb_01;
CREATE TABLE

5. 创建索引时,指定表空间

test=# create index idx_t1_id on t1(id) tablespace tb_02;
CREATE INDEX

6. 增加约束时,指定表空间

test=# alter table t1 add constraint unique_t1_id unique (id) using index tablespace tb_02;
ALTER TABLE
test=# alter table t1 add constraint pk_t1_id primary key (id) using index tablespace tb_02;
ALTER TABLE

7. 把表移动到新的表空间

test=# alter table t1 set tablespace tb_02;
ALTER TABLE
--表移动过程中会被锁定,所有的操作都被阻塞,包括Select,所以要选择合适的时间移动表。

The End!

2017-08-20

最新文章

  1. (转) 从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)
  2. webstorm--破解
  3. Linux下cutecom使用USB转串口线
  4. 【Unity Shaders】学习笔记——SurfaceShader(五)让纹理动起来
  5. Linux基本命令(7)文件阅读的命令
  6. nagios监控linux设置
  7. C++的优秀特性6:智能指针
  8. C++技术问题总结-第12篇 设计模式原则
  9. wampserver配置memcache
  10. dataset 用法(2)
  11. sublime插件(配合nodejs环境)
  12. BZOJ 1875: [SDOI2009]HH去散步(矩阵乘法)
  13. weka 通过普通文本转化成arff文件
  14. HAProxy原理和配置
  15. obtainFreshBeanFactory()源码探究
  16. 集成学习值Adaboost算法原理和代码小结(转载)
  17. web.config或App.config中AttachDBFilenamex相对路径问题
  18. POJ3254或洛谷1879 Corn Fields
  19. BZOJ4036 HAOI2015按位或(概率期望+容斥原理)
  20. 微信小程序 - 非入侵式布局

热门文章

  1. iOS开发——高级篇——线程保活
  2. VMnet1和VMnet8 未识别的网络的解决方法
  3. uwsgi 所扮演的的角色是后端 http 服务器,nginx 扮演的角色是前端 http 服务器,hello.py 是客户端应用程序
  4. CXF+Spring+Tomcat 案例
  5. get the page name from url
  6. TCP、UDP和HTTP关系
  7. 解决axios IE11 Promise对象未定义
  8. window切换Java版本原因
  9. P3161 [CQOI2012]模拟工厂
  10. ROS学习笔记三:编写第一个ROS节点程序