0
点赞
收藏
分享

微信扫一扫

面试-GC相关的面试题

JakietYu 2024-06-25 阅读 54

1.pgdumpall优缺点

2.pg_dumpall示例:

2.1导出所有数据库

pg_dumpall > all.sql 

-- 排除单个数据库 
pg_dumpall --exclude-database='testdb' -f all.sql 

-- 排除多个名字相近数据库 
pg_dumpall --exclude-database='testdb[12]' -f all.sql 

-- 排除多个名字完全不同数据库 
pg_dumpall --exclude-database='testdb' --exclude-database='newdb' -f all.sql

2.2导出所有Role和Tablespace

#仅导出 Role: 
pg_dumpall -r > pg_roles.sql 
或 
pg_dumpall -g > pg_global.sql 

# 仅导出 Tablespace: 
pg_dumpall -t > pg_tablespace.sql

3.恢复

# 导入 :不存在的会导入,存在的不导入 
psql -f pg_roles.sql

4.copy导入导出

4.1简介

4.2copy和\copy区别

4.3copy应用案例

 4.3.1从 Postgresql 导出表

-- 拷贝表至控制台,并使用竖线(|)作为字段直接的分隔符 
COPY t1 TO STDOUT (DELIMITER '|'); 

-- 拷贝表至文件,使用空格作为字段直接的分隔符 
COPY t1 TO '/tmp/t1.sql' WITH DELIMITER ' '; 

 -- 导出查询结果至文件: 
COPY (SELECT * FROM t1 WHERE name LIKE 'a%') TO '/tmp/t1.sql'; 

-- 如果需要压缩数据,使用下面命令: 
COPY t1 TO PROGRAM 'gzip > /tmp/t1.gz'; 

-- 解压 
gzip -dv t1.gz 

-- 如果仅导出 2 列,使用下面命令: 
COPY t1(name,age) TO '/tmp/t1.sql' DELIMITER ' '; 

-- 如果需要导出二进制文件: 
copy t1 to '/tmp/t1.dat' with binary; 
copy binary t1 to'/tmp/t1.dat';


-- 导出 csv 文件: 
copy t1 to '/tmp/t1.csv' with csv; 
copy t1 to '/tmp/t1.csv' with csv header; 

csv 文件还有一些其他参数: 
DELIMITER – 数据行中分割每个字段的分隔符。csv 文件一般使用逗号. 
HEADER – 指定 csv 文件的标题,如果不需要标题行,可以忽略 HEADER.

 4.3.2导入文件至PostgreSQL表

-- 传入文件至已经存在的表: 
COPY t1 FROM '/tmp/t1.sql' (DELIMITER ' '); 
COPY t1 FROM '/tmp/t1.csv' WITH delimiter ',' CSV HEADER; 

-- 指定编码: 
COPY t1 FROM '/tmp/t1.csv' WITH delimiter ',' CSV HEADER encoding 'utf-8'; 

-- 支持 WHERE 条件过滤 
COPY t1 FROM '/tmp/t1.sql' with DELIMITER '|' WHERE id < 5;

4.3.3将excel表中的数据导入到postgresql数据库中

4.3.5copy与事务

 

例子:

—copy to:

可以看到表 t1 中有 100W 条数据, copy 到文件大小为 41M

重新 copy ,然后中断该操作,发现只有部分数据被 copy to 文件中了,说明中断前的

数据没受到影响。

—copy from

copy 时进行中断。

查看:

发现表中没有任何数据,但是大小为 27MB

 可以看到,当该表被 vacuum 后,表占用的磁盘空间便被回收了。

 总结:

通过上面的实验可以的出结论,对于 copy 操作,如果中途出现问题导致中断:

copy to:不会受到影响,中断前已经 copy 的数据仍然有效;

copy from:目标表中已经拷贝的数据会变得不可见,但是仍然占用磁盘空间,等到

被 vacuum 时空间将被回收。

举报

相关推荐

0 条评论