使用PostgreSQL 脚本导出数据库的DDL

本文主要介绍如何使用基于 PostgreSQL pgdump编写的自定义脚本来导出数据库的DDL。

一、文件说明:

1、pgdump基础语句.sql:pgdump基础语法。 2、PGSQL_bak_Full.sh:实现使用pgdump导出全部对象脚本。 3、PGSQL_bak_Proc_Fun.sh:实现使用pgdump仅导出存储过程和函数对象DDL脚本。 说明:pgdump使用上述脚本导出的DDL存在少量显示问题,使用时请谨慎。 4、PGSQL_bak_Table.sh:实现使用pgdump导出指定一个或多个表、视图 DDL脚本。 注:

  • 这个脚本支持自定义数量的表对象结构导出,脚本中只有示例表名。具体使用时应人工指定,导出全部表时,建议使用PGSQL_bak_Full.sh。

  • 各脚本均支持同时导出一个或多个数据库。

二、脚本结构

具体的脚本格式如下:

#!/bin/bash
#全备方式,一般在从机上执行,适用于小中型PGSQL数据库

#source /etc/profile   #加载系统环境变量
#source ~/.bash_profile #加载用户环境变量
#set -o nounset       #引用未初始化变量时退出
#set -o errexit     #执行shell命令遇到错误时退出

#01 连接数据库所需认证信息
user="postgres"
password="****************"
host="106.54.134.160"
port="5432"
#02 需备份的数据库,数组形式,如果只需备份一个数据库,只需保留一个库名称即可
db=("postgres" "kingland")
#03 备份路径及文件名格式设置
pgsql_path="/usr/local/backupdata"
backup_path="${pgsql_path}/backup"
date=$(date +%Y-%m-%d_%H-%M-%S)
backup_log="${pgsql_path}/backup.log"
#建立备份目录
if [ ! -e $backup_path ];then
mkdir -p $backup_path
fi

echo "开始备份数据库:${db[*]}"

#04 备份
backup_sql(){
dbname=$1
backup_name="${dbname}_${date}.sql"
#-R备份存储过程,函数,触发器
pg_dump -s "host=$host user=$user port=$port password=$password dbname= $dbname">$backup_path/$backup_name
if [[ $? == 0 ]];then
  cd $backup_path
  echo "$date 备份 $dbname成功 "
else
  cd $backup_path
  rm -rf $backup_name
  echo "$date 备份 $dbname 失败 "
fi
}

#05 循环备份
length=${#db[@]}
for (( i = 0; i < $length; i++ )); do
  backup_sql ${db[$i]} >> $backup_log 2>&1
done

echo "备份结束,结果查看 $backup_log"
du $backup_path/*$date* -sh | awk '{print "文件:" $2 ",大小:" $1}'

说明:

01:连接数据库所需认证信息

用户为数据库用户和密码,端口号为默认的5432;

02:需备份的数据库

支持一个或多个数据库备份,数据库名称需要使用双引号引起来;

03:备份路径及文件名格式设置

要确保pgsql_path变量中对应的物理路径要存在,特别是backup文件夹也要提前建好;具体的文件名称格式使用时间后缀,该格式可以自定义;

04、05:循环备份

根据前面的配置进行循环备份,如果备份失败,脚本会自动删除过程备份数据。

备份记录自动记录log文件到backup.log中。

三、其他说明

各文件关键参数区别

1、PGSQL_bak_Full.sh

  #-R备份存储过程,函数,触发器
pg_dump -s "host=$host user=$user port=$port password=$password dbname= $dbname">$backup_path/$backup_name

-s

--schema-only

只输出对象定义(模式),不输出数据。

2、PGSQL_bak_Proc_Fun.sh

  #-Fc备份存储过程(函数)定义
pg_dump -s -Fc "host=$host user=$user port=$port password=$password dbname= $dbname">$backup_path/$backup_name

3、PGSQL_bak_Table.sh

 #--t只导出指定表 这里示例表test ,实际使用中应按需指定
pg_dump -s -t test "host=$host user=$user port=$port password=$password dbname= $dbname">$backup_path/$backup_name

这里的test是测试表,实际生产活动中应修改为对应的表名;如果一次性要导出多个表,使用pg_dump -t table1 -t table2 -t table3 这种格式。

四、结果说明

导出结构文本内容格式:

--
-- PostgreSQL database dump
--

-- Dumped from database version 10.15 (Ubuntu 10.15-0ubuntu0.18.04.1)
-- Dumped by pg_dump version 10.15 (Ubuntu 10.15-0ubuntu0.18.04.1)

SET statement_timeout = 0;
SET lock_timeout = 0;
SET idle_in_transaction_session_timeout = 0;
SET client_encoding = 'UTF8';
SET standard_conforming_strings = on;
SELECT pg_catalog.set_config('search_path', '', false);
SET check_function_bodies = false;
SET xmloption = content;
SET client_min_messages = warning;
SET row_security = off;

--
-- Name: DATABASE postgres; Type: COMMENT; Schema: -; Owner: postgres
--
COMMENT ON DATABASE postgres IS 'default administrative connection database';
--
-- Name: plpgsql; Type: EXTENSION; Schema: -; Owner:
--
CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;
--
-- Name: EXTENSION plpgsql; Type: COMMENT; Schema: -; Owner:
--
COMMENT ON EXTENSION plpgsql IS 'PL/pgSQL procedural language';
--
-- Name: delete_ebd_compute_log_three_month_ago_data(); Type: FUNCTION; Schema: public; Owner: postgres
--
CREATE FUNCTION public.delete_ebd_compute_log_three_month_ago_data() RETURNS void
  LANGUAGE plpgsql
  AS $$
begin
select * from test;
END;
$$;

ALTER FUNCTION public.delete_ebd_compute_log_three_month_ago_data() OWNER TO postgres;
--
-- Name: sales_tax(real); Type: FUNCTION; Schema: public; Owner: postgres
--

CREATE FUNCTION public.sales_tax(subtotal real) RETURNS real
  LANGUAGE plpgsql
  AS $$
  BEGIN
    RETURN subtotal * 0.06;
  END;
  $$;

ALTER FUNCTION public.sales_tax(subtotal real) OWNER TO postgres;
SET default_tablespace = '';
SET default_with_oids = false;

--
-- Name: test; Type: TABLE; Schema: public; Owner: postgres
--

CREATE TABLE public.test (
  id integer,
  name character varying(38)
);
ALTER TABLE public.test OWNER TO postgres;

--
-- Name: v_test; Type: VIEW; Schema: public; Owner: postgres
--
CREATE VIEW public.v_test AS
SELECT test.id,
  test.name
  FROM public.test;

ALTER TABLE public.v_test OWNER TO postgres;
--
-- PostgreSQL database dump complete
--

使用PostgreSQL 脚本导出数据库的DDL的更多相关文章

  1. MySQL导入sql脚本 导出数据库

    导出数据库 不能停止服务 cd /var/lib/mysql (进入到MySQL库目录,根据自己的MySQL的安装情况调整目录) mysqldump -u用户名 -p 数据库名 > 导出的文件名 ...

  2. POSTGRESQL 创建表结构、修改字段、导入导出数据库(支持CSV)

    这两个月经常使用postgresql,总结一些经常使用的语句: --创建表 CREATE TABLE customers ( customerid SERIAL primary key , compa ...

  3. DAC--使用DAC来导出数据库脚本

    //============================================== //功能介绍:使用DAC来导出数据库脚本 //注意事项: //1.本程序涉及到的DLL有: //  - ...

  4. 使用python脚本从数据库导出数据到excel

    python从数据库导出数据到excel 最近需要从数据库里导出一些数据到excel,刚开始我是使用下面的命令 select * from xxx where xxx into outfile 'xx ...

  5. PD脚本导出到数据库后没有注释问题

    昨天PD里建了几张表,建表的时候我在NAME栏位写了中文说明,但是脚本在数据库里生成表以后,发现中文说明没有了,需要自己在“注释”栏位添加才行,如下图: 我想要达到的效果如下图: 解决方法: 1.  ...

  6. MySQL之 Mysqldump导出数据库

    参数大全 参数说明 --all-databases , -A 导出全部数据库. mysqldump -uroot -p --all-databases --all-tablespaces , -Y 导 ...

  7. DB2导入导出数据库数据

    导出数据库中数据 在db2cmd命令下生成建库脚本(-z指定模式名) db2look -d BBS -z db2admin -u db2admin -e -o bbs.sql 在db2cmd命令下导出 ...

  8. 使用PLSQL导入导出数据库

    Oracle如何实现创建数据库.备份数据库及数据导出导入的一条龙操作 Oracle中对数据对象和数据的管理,无疑都是使用PL/SQL Developer来进行管理,该工具也提供给我们很多方便.快捷的操 ...

  9. mysql导出数据库几种方法

    方法一 cmd 到mysql bin目录下用 如下命令 mysqldump --opt -h192.168.0.156 -uusername -ppassword --skip-lock-tables ...

随机推荐

  1. CSP2019 Day2T3 树的重心

    显然如果我们直接枚举断哪条边,剩下的两颗树的重心编号非常不好求,一个常见的想法是我们反过来,考虑每个节点有多少种情况作为树的重心,计算每个点对答案的贡献. 下面我们就需要大力分类讨论了.假设我们现在考 ...

  2. 广播接收者案例_sd卡状态监听

    (1)定义广播接收者 import android.content.BroadcastReceiver; import android.content.Context; import android. ...

  3. node.js中的fs.appendFile方法使用说明

    方法说明: 该方法以异步的方式将 data 插入到文件里,如果文件不存在会自动创建.data可以是任意字符串或者缓存. 语法: 代码如下: fs.appendFile(filename, data, ...

  4. Protocol基本概念

    1.protocol 基本概念 Protocol翻译过来, 叫做"协议" 在写java的时候都会有接口interface这个概念,接口就是一堆方法的声明没有实现,而在OC里面Int ...

  5. 【转载收藏】使用Jacoco远程统计tomcat服务的代码覆盖率

    在做软件开发的时候经常会遇到做各种测试,这里介绍一种本人遇到的:代码覆盖率测试, 这个测试非常实用,能发现许多无效的模块和代码.强烈推荐!!!!! 网上好多资料都不全,而且没有详细的配置流程 本文将简 ...

  6. llinux_2

    1.显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录 [root@lhq ~]#ls /etc/ | grep "^[^[:alpha:]][[:alp ...

  7. 虫师Selenium2+Python_8、自动化测试高级应用

    P205--HTML测试报告 P213--自动发邮件功能 P221--Page Object 设计模式

  8. 框架5--nginx安装部署 下(web服务)

    目录 1.提纲 2.Nginx虚拟主机 3.Nginx日志 4.Nginx访问控制模块 5.Nginx状态监控模块 6.访问连接控制模块 框架5--nginx安装部署 下(web服务) 1.提纲 1. ...

  9. 原来VIM还可以这样玩

    文章目录 配置文件vimrc vim 状态栏 状态栏配置内容 状态栏常用信息 显示状态栏 终端安全色 vimrc 配置文件 推荐 vi/vim命令大全 vim参阅 配置文件vimrc 在vim文件中执 ...

  10. Dubbo源码剖析六之SPI扩展点的实现之Adaptive功能实现原理

    接Dubbo源码剖析六之SPI扩展点的实现之getExtensionLoader - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)继续分析Adaptive功能实现原理.Adaptive的主 ...