导出模式

openGauss目前支持使用gs_dump工具导出模式级的内容,包含模式的数据和定义。用户可通过灵活的自定义方式导出模式内容,不仅支持选定一个模式或多个模式的导出,还支持排除一个模式或者多个模式的导出。可根据需要自定义导出如下信息:

  • 导出模式全量信息,包含数据和对象定义。
  • 仅导出数据,即模式包含表中的数据,不包含对象定义。
  • 仅导出模式对象定义,包括:表定义、存储过程定义和索引定义等。

操作步骤

  1. 以操作系统用户omm登录数据库主节点。
  2. 使用gs_dump同时导出hr和public模式。

    1. gs_dump -U jack -f /home/omm/backup/MPPDB_schema_backup -p 8000 human_resource -n hr -n public -F d
    2. Password:

    表 1 常用参数说明

    参数

    参数说明

    举例

    -U

    连接数据库的用户名。

    -U jack

    -W

    指定用户连接的密码。

    • 如果主机的认证策略是trust,则不会对数据库管理员进行密码验证,即无需输入-W选项。
    • 如果没有-W选项,并且不是数据库管理员,会提示用户输入密码。

    -W abcd@123

    -f

    将导出文件发送至指定目录文件夹。如果这里省略,则使用标准输出。

    -f /home/omm/backup/MPPDB_schema_backup

    -p

    指定服务器所侦听的TCP端口或本地Unix域套接字后缀,以确保连接。

    -p 8000

    dbname

    需要导出的数据库名称

    human_resource

    -n

    只导出与模式名称匹配的模式,此选项包括模式本身和所有它包含的对象。

    • 单个模式:-n schemaname
    • 多个模式:多次输入-n schemaname
    • 单个模式:-n hr
    • 多个模式:-n hr -n public

    -F

    选择导出文件格式。-F参数值如下:

    • p:纯文本格式
    • c:自定义归档
    • d:目录归档格式
    • t:tar归档格式

    -F d

    其他参数说明请参见《工具参考》中“服务端工具 > gs_dump”章节。

示例

示例一:执行gs_dump,导出hr模式全量信息,导出文件格式为文本格式。

  1. gs_dump -f /home/omm/backup/MPPDB_schema_backup.sql -p 8000 human_resource -n hr -F p
  2. Password:
  3. gs_dump[port='8000'][human_resource][2017-07-21 16:05:55]: dump database human_resource successfully
  4. gs_dump[port='8000'][human_resource][2017-07-21 16:05:55]: total time: 2425 ms

示例二:执行gs_dump,仅导出hr模式的数据,导出文件格式为tar归档格式。

  1. gs_dump -f /home/omm/backup/MPPDB_schema_data_backup.tar -p 8000 human_resource -n hr -a -F t
  2. Password:
  3. gs_dump[port='8000'][human_resource][2018-11-14 15:07:16]: dump database human_resource successfully
  4. gs_dump[port='8000'][human_resource][2018-11-14 15:07:16]: total time: 1865 ms

示例三:执行gs_dump,仅导出hr模式的定义,导出文件格式为目录归档格式。

  1. gs_dump -f /home/omm/backup/MPPDB_schema_def_backup -p 8000 human_resource -n hr -s -F d
  2. Password:
  3. gs_dump[port='8000'][human_resource][2018-11-14 15:11:34]: dump database human_resource successfully
  4. gs_dump[port='8000'][human_resource][2018-11-14 15:11:34]: total time: 1652 ms

示例四:执行gs_dump,导出human_resource数据库时,排除hr模式,导出文件格式为自定义归档格式。

  1. gs_dump -f /home/omm/backup/MPPDB_schema_backup.dmp -p 8000 human_resource -N hr -F c
  2. Password:
  3. gs_dump[port='8000'][human_resource][2017-07-21 16:06:31]: dump database human_resource successfully
  4. gs_dump[port='8000'][human_resource][2017-07-21 16:06:31]: total time: 2522 ms

示例五:执行gs_dump,同时导出hr和public模式,且仅导出模式定义,导出文件格式为tar归档格式。

  1. gs_dump -f /home/omm/backup/MPPDB_schema_backup1.tar -p 8000 human_resource -n hr -n public -s -F t
  2. gs_dump[port='8000'][human_resource][2017-07-21 16:07:16]: dump database human_resource successfully
  3. gs_dump[port='8000'][human_resource][2017-07-21 16:07:16]: total time: 2132 ms

示例六:执行gs_dump,导出human_resource数据库时,排除hr和public模式,导出文件格式为自定义归档格式。

  1. gs_dump -f /home/omm/backup/MPPDB_schema_backup2.dmp -p 8000 human_resource -N hr -N public -F c
  2. Password:
  3. gs_dump[port='8000'][human_resource][2017-07-21 16:07:55]: dump database human_resource successfully
  4. gs_dump[port='8000'][human_resource][2017-07-21 16:07:55]: total time: 2296 ms

示例七:执行gs_dump,导出public模式下所有表(视图、序列和外表)和hr模式中staffs表,包含数据和表定义,导出文件格式为自定义归档格式。

  1. gs_dump -f /home/omm/backup/MPPDB_backup3.dmp -p 8000 human_resource -t public.* -t hr.staffs -F c
  2. Password:
  3. gs_dump[port='8000'][human_resource][2018-12-13 09:40:24]: dump database human_resource successfully
  4. gs_dump[port='8000'][human_resource][2018-12-13 09:40:24]: total time: 896 ms