对于想了解需要将mssql备份文件的读者,本文将是一篇不可错过的文章,我们将详细介绍.bak文件导入postgres,并且为您提供关于centos7下源码编译安装php支持PostgreSQLpost
对于想了解需要将 mssql 备份文件的读者,本文将是一篇不可错过的文章,我们将详细介绍.bak 文件导入 postgres,并且为您提供关于centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教、Hawq学习笔记 --- postgresql 导入sql文件、pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库、pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。的有价值信息。
本文目录一览:- 需要将 mssql 备份文件(.bak 文件)导入 postgres(mssql备份数据库)
- centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教
- Hawq学习笔记 --- postgresql 导入sql文件
- pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库
- pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。
需要将 mssql 备份文件(.bak 文件)导入 postgres(mssql备份数据库)
如何解决需要将 mssql 备份文件(.bak 文件)导入 postgres?
需要将 MSsql 备份文件(.bak 文件)直接导入 postgres,我没有安装 MSsql 也无法在我的机器上安装它,有什么方法可以直接将 MSsql bak 文件导入 postgres 本地数据库
提前谢谢你!!
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教
1. 下载源码
$ mkdir /usr/downloads $ wget -c http://cn2.php.net/distributions/php-5.6.20.tar.gz $ tar -xvf php-5.6.20.tar.gz $ mv php-5.6.20 /usr/local/src $ cd !$ & cd php-5.6.20
2. 阅读安装指导
$ ls -also $ less README $ less INSTALL
3. 安装依赖包
$ yum install apr apr-util apr-devel apr-util-devel prce lynx
4. 安装httpd
$ wget -c http://apache.fayea.com//httpd/httpd-2.4.20.tar.gz $ tar -xvf httpd-2.4.20.tar.gz $ cd httpd-2.4.20 $ ./configure \ --prefix=/usr/local/programs/apache2 \ --enable-rewrite \ --enable-so \ --enable-headers \ --enable-expires \ --with-mpm=worker \ --enable-modules=most \ --enable-deflate \ --enable-module=shared $ make $ make install $ cd /usr/local/programs/apache2 $ cp bin/apachectl /etc/init.d/httpd ## 复制启动脚本 $ /etc/init.d/httpd start ## 启动apache服务器,访问http://localhost/ $ egrep -v ''^[ ]*#|^$'' /usr/local/apache2/conf/httpd.conf | nl ## 查看apache服务器的配置 ## 将apache加入系统服务 vi /etc/rc.d/rc.local ``` /usr/local/programs/apache2/bin/apachectl start ``` $ cat /etc/rc.local
4. 安装postgresql
立即学习“PHP免费学习笔记(深入)”;
$ yum install readline-devel ## 安装readline依赖 $ cd /usr/downloads $ wget -c https://ftp.postgresql.org/pub/source/v9.5.0/postgresql-9.5.0.tar.bz2 $ tar -xvf postgresql-9.5.0.tar.bz2 $ cd postgresql-9.5.0 $ ./configure --prefix=/usr/local/programs/postgresql $ make $ su $ make install $ /sbin/ldconfig /usr/local/programs/postgresql/lib ## 刷新下共享动态库 $ cd /usr/local/programs/postgresql $ bin/psql --version ## 检查运行情况 ## 开始对postgresql的配置 $ vi /etc/profile.d/postgresql.sh ## 增加环境变量,不推荐直接在/etc/profile中添加,系统更新升级时会需要merge ``` PATH=/usr/local/programs/postgresql:$PATH export PATH ``` $ source /etc/profile ## 更新环境变量 ## 增加用户和其他文件夹 $ adduser postgres $ passwd postgres $ mkdir /usr/local/programs/postgresql/logs $ mkdir /usr/local/programs/postgresql/data $ chown postgres /usr/local/programs/postgresql/data $ su - postgres ## 初始化数据库 $ ./bin/initdb -D ./data $ ./bin/createdb test $ ./bin/psql test ## 已有数据库,可导入data文件夹后尝试root访问,假如带密码,可能需要进一步研究下 $ ./bin/postgres -D ./data >./logs/start-log-1.log 2>&1 & $ ./bin/psql --list ##列出数据库 ## ok,安装完成 ## 自定义设置,权限控制等,可以跳过,等熟悉使用后再做 ## 编辑数据库配置及权限文件: $ vi /usr/local/programs/postgresql/data/postgresql.conf ## 数据库配置文件 $ chown postgres postgresql.conf $ chmod 644 postgresql.conf $ vi /usr/local/programs/postgresql/data/pg_hba.conf ## 权限文件 $ vi /usr/local/programs/postgresql/data/pg_ident.conf ## 设置开机自启动: $ vi /etc/rc.d/rc.local ## 添加如下内容 ``` /usr/local/programs/postgresql/bin/postgresql start ```
5. 安装php
## 源码已经在第一步中下载,现在开始安装: $ yum install libxml2 libxml2-devel libpng libpng-devel libjpeg libjpeg-devel freetype freetype-devel $ ./configure \ --prefix=/usr/local/programs/php \ --with-apxs2=/usr/local/programs/apache2/bin/apxs \ --with-zlib \ --with-gd \ --with-jpeg-dir \ --with-png-dir \ --with-freetype-dir \ --with-zlib-dir \ --enable-mbstring \ --with-pgsql=/usr/local/programs/postgresql \ --with-pdo-pgsql=/usr/local/programs/postgresql $ make $ make test > Bug #42718 (unsafe_raw filter not applied when configured as default filter) [ext/filter/tests/bug42718.phpt] XFAIL REASON: FILTER_UNSAFE_RAW not applied when configured as default filter, even with flags > Bug #67296 (filter_input doesn''t validate variables) [ext/filter/tests/bug49184.phpt] XFAIL REASON: See Bug #49184 > Bug #53640 (XBM images require width to be multiple of 8) [ext/gd/tests/bug53640.phpt] XFAIL REASON: Padding is not implemented yet > zend multibyte (7) [ext/mbstring/tests/zend_multibyte-07.phpt] XFAIL REASON: https://bugs.php.net/bug.php?id=66582 > zend multibyte (9) [ext/mbstring/tests/zend_multibyte-09.phpt] XFAIL REASON: https://bugs.php.net/bug.php?id=66582 >Bug #70470 (Built-in server truncates headers spanning over TCP packets) [sapi/cli/tests/bug70470.phpt] XFAIL REASON: bug is not fixed yet ## 查阅官方的bug,发现: > id=66582: status : Closed. Fixed in master (PHP7) > id=42718: status : Assigned > id=42718: reference to id=49184, unsolved for many years ## 那就不关心了,直接装吧 $ make install > You may want to add: /usr/local/programs/php/lib/php to your php.ini include_path ## 那就按它说的设置吧 $ cp php.ini-development /usr/local/programs/php/lib/php.ini ``` include_path = ".;/usr/local/programs/php/lib/php" ## 然后,编辑httpd的设置,确保其能正确解析php文件 ``` ... LoadModule php5_module modules/libphp5.so ... AddType application/x-httpd-php .php AddType application/x-httpd-php-source .php5 ... <ifmodule dir_module> DirectoryIndex index.html index.php </ifmodule> ``` ## 重启httpd,测试 $ cd /usr/local/programs/apache2 $ bin/httpd -h $ bin/httpd -k stop $ bin/httpd -f conf/httpd.conf ## 默认设置的www页面在./htdocs/下,那就先去里面建一个测试页面吧 $ vi htdocs/index.php ``` <?php phpinfo(); ?> ``` $ curl http://localhost/index.php |grep postgresql #ok
后续应该做的事
* 1. 启动时,不需要要手动指定配置文件
* 2. php初始化www目录设置
* 3. php 用户、权限管理等
以上就介绍了centos 7下源码编译安装php支持PostgreSQL,包括了postgresql,centos 7方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
Hawq学习笔记 --- postgresql 导入sql文件
>psql -h localhost -ddatabaseName -U username -f filenamepg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库
NAME
pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 Postgresql 数据库。
SYnopSIS
pg_restore [ option... ] [ filename ] DESCRIPTION ����述 pg_restore 是一种用于恢复由 pg_dump(1) 创建的任何非纯文本输出格式中的 Postgresql 数据库的应用。 它将发出必要的命令来重新构造数据库,以便于把它恢复成保存它的时候的样子。 归档(备份)文件还允许pg_restore 有选择地进行恢复, 甚至在恢复前重新排列条目的顺序。归档的文件设计成可以在不同的硬件体系之间移植。 pg_restore 可以以两种模式操作:如果声明了数据库名字, 那么归档是直接恢复到数据库里。大对象只能用直接数据库联接进行恢复。 否则,先创建一个包含重建数据库所必须的 sql 命令的脚本(并且写入到一个文件或者标准输出), 类似 pg_dump 输出纯文本格式的时候创建的那种脚本。 因此,一些控制脚本输出的选项就是摹拟 pg_dump 的操作。 显然,pg_restore 无法恢复那些不存在归档文件中的信息; 比如,如果归档是用"把数据转储为 INSERT命令"选项制作的, 那么 pg_restore 将不能使用 copY 语句装载数据。 OPTIONS����项 pg_restore 接受下列命令行参数。 filename 声明要恢复的备份文件的位置。如果没有声明,则使用标准输入。 -a --data-only 只恢复数据,而不恢复表模式(数据定义)。 -c --clean 创建数据库对象前先清理(删除)它们。 -C --create 在恢复数据库之前先创建它。(如果出现了这个选项,和 -d 在一起的数据库名只是用于发出最初的 CREATE DATABASE 命令。 所有数据都恢复到名字出现在归档中的数据库中去。) -d dbname --dbname=dbname 与数据库 dbname 联接并且直接恢复到该数据库中。 -f filename --file=filename 声明生成的脚本的输出文件,或者出现 -l 选项时用于列表的文件,缺省是标准输出。 -F format --format=format 声明备份文件的格式。因为pg_restore 会自动判断格式,所以如果声明了,它可以是下面之一: t 备份是一个 tar 归档。 使用这个格式允许在恢复数据库的时候重新排序和/或把表模式元素排除出去。 同时还可能在恢复的时候限制装载的数据。 c 备份的格式是来自 pg_dump 的客户化格式。 这是最灵活的格式,因为它允许重新对数据排序,也允许重载表模式元素。 缺省时这个格式是压缩的。 -i --ignore-version 忽略数据库版本检查。 -I index --index=index 只恢复命名的索引。 -l --list 列出备份的内容。这个操作的输出可以用 -L 选项限制和重排所恢复的项目。 -L list-file --use-list=list-file 只恢复在 list-file 里面的元素,以它们在文件中出现的顺序。 你可以移动各个行并且也可以通过在行开头放 ';' 的方式注释。(见下文获取例子。) -N --orig-order 以最初在 pg_dump 里生成的转储顺序恢复项目。 这个选项没有什么实际的用途,因为 pg_dump 会以自己方便的顺序生成项, 这个顺序不可能是恢复这些数据的安全顺序。 (这个顺序不是项最后在归档的内容列表中列出的顺序。) 又见 -r。 -o --oid-order 以 OID 顺序恢复项目。这个选项用处很小, 因为 OID 只是最初创建顺序的一个近似指示。 如果还声明了 -N,那么这个选项还覆盖它。又见 -r。 -O --no-owner 不要输出设置对象的权限,以便与最初的数据库匹配的命令。 缺省时,pg_restore 发出 SET SESSION AUTHORIZATION 语句设置创建出来的模式元素的所有者权限。 如果最初的数据库连接不是由超级用户(或者是拥有所有创建出来的对象的同一个用户)发起的,那么这些语句将失败。 使用 -O,那么任何用户都可以用于初始的连接,并且这个用户将拥有所有创建出来的对象。 -P function-name(argtype [,...]) --function=function-name(argtype [,...]) 只恢复指定的命名函数。请注意仔细拼写函数名及其参数,应该和转储的内容列表中的完全一样。 -r --rearrange 以对象类型重排项目(这个发生在以 -N 或者 -o 排序之后)。 重排是为了给出最大可能的性能。 如果没有 -N,-o,和-r,那么 pg_restore 以项目出现在归档 的内容列表中的顺序恢复他们, 或者按照他们在 list-file 里面的顺序恢复他们 -- 假如给出了 -L 的话。 -o 和 -r 的组合复制了 pg_dump 在创建归档的内容列表 之前进行的排序, 因此,这个选项通常没必要声明。 -R --no-reconnect 这个选项已痉掀耍俏吮3窒蛳录嫒萑匀唤邮堋 -s --schema-only 只恢复表结构(数据定义)。不恢复数据,序列值将重置。 -S username --superuser=username 设置关闭触发器时声明超级用户的用户名。 只有在设置了 --disable- triggers 的时候才有用。 -t table --table=table 只恢复表指定的表的定义和/或数据。 -T trigger --trigger=trigger 只恢复指定的触发器。 -v --verbose 声明冗余模式。 -x --no-privileges --no-acl 避免 ACL 的恢复(grant/revoke 命令)。 -X use-set-session-authorization --use-set-session-authorization 这个选项已痉掀耍浅鲇谙蛳录嫒荩匀唤邮堋 pg_restore 现在总是表现得像以前选中这个选项一样。 -X disable-triggers --disable-triggers 这个选项只有在执行仅恢复数据的时候才相关。它告诉 pg_restore 在装载数据的时候执行一些命令临时关闭在目标表上的触发器。 如果你在表上有完整性检查或者其它触发器, 而你又不希望在装载数据的时候激活它们,那么可以使用这个选项。 目前,为 --disable-triggers 发出的命令必须以超级用户发出。 因此,你应该也要用 -S 声明一个超级用户名,或者更好是设置 --use- set-session-authorization 并且以 Postgresql 超级用户身份运行 pg_restore。 pg_restore 还接受下面的命令行参数做为联接参数: -h host --host=host 声明服务器运行的机器的主机名。 如果数值以斜扛开头,那么它被用做 Unix 域套接字的目录。 缺省是从 PGHOST 环境变量中获取的(如果设置了), 否则将尝试进行 Unix 域套接字。 -p port --port=port 声明服务器侦听的 TCP 端口或者本地的 Unix 域套接字文件扩展。 缺省是环境变量 PGPORT 的值(如果设置了的话), 否则就说编译的缺省。 -U username 以给出用户身分联接。 -W 强制给出口令提示。如果服务器要求口令认证,那么这个应该自动发生。 ENVIRONMENT����境 PGHOST PGPORT PGUSER 缺省连接参数。 DIAGNOSTICS����断 当使用-d选项声明了直接数据库联接时, pg_restore 在内部执行 sql 语句。如果你运行 pg_restore 出了毛病, 请确保你能用类似 psql(1) 这样的东西从数据库中选取信息。 NOTES����意 如果你的安装给template1数据库增加了任何你自己的东西, 那么请注意把 pg_dump 的输出恢复到一个真正空的数据库中; 否则你可能会收到因为重复定义所追加的对象而造成的错误信息。要制作一个没有任何本地附属物的数据库, 可以从template0而不是template1拷贝,比如: CREATE DATABASE foo WITH TEMPLATE template0; pg_restore 的局限在下面列出。 o 当向一个已敬嬖诘谋砘指词荩⑶一故褂昧 --disable-triggers 选项时, pg_restore 在插入数据前放出一些查询关闭用户表上的触发器, 在数据插入完成后重新打开它们。如果恢复的中途停止,那么系统表可能处于错误状态。 o pg_restore 将不会为单一的表恢复大对象。 如果一个归档包含大对象,那么所有大对象都将被恢复。 又见参阅 pg_dump(1) 的文挡获取有关 pg_dump 的局限的细节。 一旦完成恢复,最好在每个恢复的对象上运行 ANALYZE, 以便给优化器有用的统计。 EXAMPLES��子 把一个包含大对象的叫 mydb 的数据库转储到一个tar文件: $ pg_dump -Ft -b mydb > db.tar 把这个数据库恢复到现有的叫 newdb 的数据库中(连同BLOB): $ pg_restore -d newdb db.tar 要对项目重新排序,首先必须转储归档的目录: $ pg_restore -l archive.file > archive.list 这个文件由一行头和每个项目一行组成,比如。 ; ; Archive created at Fri Jul 28 22:28:36 2000 ; dbname: birds ; TOC Entries: 74 ; Compression: 0 ; Dump Version: 1.4-0 ; Format: CUSTOM ; ; ; Selected TOC Entries: ; 2; 145344 TABLE species postgres 3; 145344 ACL species 4; 145359 TABLE nt_header postgres 5; 145359 ACL nt_header 6; 145402 TABLE species_records postgres 7; 145402 ACL species_records 8; 145416 TABLE ss_old postgres 9; 145416 ACL ss_old 10; 145433 TABLE map_resolutions postgres 11; 145433 ACL map_resolutions 12; 145443 TABLE hs_old postgres 13; 145443 ACL hs_old 这里分号是注释分隔符,而行开头的数字代表赋给每个项目的内部归档 ID。 文件内的行可以注释掉,删除和/或重新排列。比如, 10; 145433 TABLE map_resolutions postgres ;2; 145344 TABLE species postgres ;4; 145359 TABLE nt_header postgres 6; 145402 TABLE species_records postgres ;8; 145416 TABLE ss_old postgres 可以用做 pg_restore 的输入并且只会恢复项目 10 和 6,(以这个顺序): $ pg_restore -L archive.list archive.file HISTORY��史 pg_restore 工具第一次出现在 Postgresql 7.1。 SEE ALSO����见 pg_dump(1),pg_dumpall(1),psql(1) ����者 Postgresql������������ ���������� <laser@pgsqldb.org>
pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。
SYNOPSIS
pg_restore [ option...] [ filename]
DESCRIPTION 描述
pg_restore 是一种用于恢复由 pg_dump(1) 创建的任何非纯文本输出格式中的 PostgreSQL 数据库的应用。 它将发出必要的命令来重新构造数据库,以便于把它恢复成保存它的时候的样子。 归档(备份)文件还允许 pg_restore 有选择地进行恢复, 甚至在恢复前重新排列条目的顺序。归档的文件设计成可以在不同的硬件体系之间移植。
pg_restore 可以以两种模式操作:如果声明了数据库名字, 那么归档是直接恢复到数据库里。大对象只能用直接数据库联接进行恢复。 否则,先创建一个包含重建数据库所必须的 SQL 命令的脚本(并且写入到一个文件或者标准输出), 类似 pg_dump 输出纯文本格式的时候创建的那种脚本。 因此,一些控制脚本输出的选项就是摹拟 pg_dump 的操作。
显然,pg_restore 无法恢复那些不存在归档文件中的信息; 比如,如果归档是用 "把数据转储为 INSERT 命令" 选项制作的, 那么 pg_restore 将不能使用 COPY 语句装载数据。
OPTIONS 选项
pg_restore 接受下列命令行参数。
- filename
-
声明要恢复的备份文件的位置。如果没有声明,则使用标准输入。 - -a
- --data-only
-
只恢复数据,而不恢复表模式(数据定义)。 - -c
- --clean
-
创建数据库对象前先清理(删除)它们。 - -C
- --create
-
在恢复数据库之前先创建它。(如果出现了这个选项,和 -d 在一起的数据库名只是用于发出最初的 CREATE DATABASE 命令。 所有数据都恢复到名字出现在归档中的数据库中去。) - -d dbname
- --dbname= dbname
-
与数据库 dbname 联接并且直接恢复到该数据库中。 - -f filename
- --file= filename
-
声明生成的脚本的输出文件,或者出现 -l 选项时用于列表的文件,缺省是标准输出。 - -F format
- --format= format
-
声明备份文件的格式。因为 pg_restore 会自动判断格式,所以如果声明了,它可以是下面之一:-
- t
-
备份是一个 tar 归档。 使用这个格式允许在恢复数据库的时候重新排序和 / 或把表模式元素排除出去。 同时还可能在恢复的时候限制装载的数据。 - c
-
备份的格式是来自 pg_dump 的客户化格式。 这是最灵活的格式,因为它允许重新对数据排序,也允许重载表模式元素。 缺省时这个格式是压缩的。
- -i
- --ignore-version
-
忽略数据库版本检查。 - -I index
- --index= index
-
只恢复命名的索引。 - -l
- --list
-
列出备份的内容。这个操作的输出可以用 -L 选项限制和重排所恢复的项目。 - -L list-file
- --use-list= list-file
-
只恢复在 list-file 里面的元素,以它们在文件中出现的顺序。 你可以移动各个行并且也可以通过在行开头放 '';'' 的方式注释。(见下文获取例子。) - -N
- --orig-order
-
以最初在 pg_dump 里生成的转储顺序恢复项目。 这个选项没有什么实际的用途,因为 pg_dump 会以自己方便的顺序生成项, 这个顺序不可能是恢复这些数据的安全顺序。 (这个顺序不是项最后在归档的内容列表中列出的顺序。) 又见 -r。 - -o
- --oid-order
-
以 OID 顺序恢复项目。这个选项用处很小, 因为 OID 只是最初创建顺序的一个近似指示。 如果还声明了 -N,那么这个选项还覆盖它。又见 -r。 - -O
- --no-owner
-
不要输出设置对象的权限,以便与最初的数据库匹配的命令。 缺省时,pg_restore 发出 SET SESSION AUTHORIZATION 语句设置创建出来的模式元素的所有者权限。 如果最初的数据库连接不是由超级用户(或者是拥有所有创建出来的对象的同一个用户)发起的,那么这些语句将失败。 使用 -O,那么任何用户都可以用于初始的连接,并且这个用户将拥有所有创建出来的对象。 - -P function-name(argtype [, ...])
- --function= function-name(argtype [, ...])
-
只恢复指定的命名函数。请注意仔细拼写函数名及其参数,应该和转储的内容列表中的完全一样。 - -r
- --rearrange
-
以对象类型重排项目(这个发生在以 -N 或者 -o 排序之后)。 重排是为了给出最大可能的性能。如果没有 -N, -o, and -r,那么 pg_restore 以项目出现在归档的内容列表中的顺序恢复他们, 或者按照他们在 list-file 里面的顺序恢复他们 —— 假如给出了 -L 的话。 -o 和 -r 的组合复制了 pg_dump 在创建归档的内容列表之前进行的排序, 因此,这个选项通常没必要声明。
- -R
- --no-reconnect
-
这个选项已经废弃了,但是为了保持向下兼容仍然接受。 - -s
- --schema-only
-
只恢复表结构(数据定义)。不恢复数据,序列值将重置。 - -S username
- --superuser= username
-
设置关闭触发器时声明超级用户的用户名。 只有在设置了 --disable-triggers 的时候才有用。 - -t table
- --table= table
-
只恢复表指定的表的定义和 / 或数据。 - -T trigger
- --trigger= trigger
-
只恢复指定的触发器。 - -v
- --verbose
-
声明冗余模式。 - -x
- --no-privileges
- --no-acl
-
避免 ACL 的恢复(grant/revoke 命令)。 - -X use-set-session-authorization
- --use-set-session-authorization
-
这个选项已经废弃了,但是出于向下兼容,仍然接受。 pg_restore 现在总是表现得像以前选中这个选项一样。 - -X disable-triggers
- --disable-triggers
-
这个选项只有在执行仅恢复数据的时候才相关。它告诉 pg_restore 在装载数据的时候执行一些命令临时关闭在目标表上的触发器。 如果你在表上有完整性检查或者其它触发器, 而你又不希望在装载数据的时候激活它们,那么可以使用这个选项。
目前,为 --disable-triggers 发出的命令必须以超级用户发出。 因此,你应该也要用 -S 声明一个超级用户名,或者更好是设置 --use-set-session-authorization 并且以 PostgreSQL 超级用户身份运行 pg_restore。
pg_restore 还接受下面的命令行参数做为联接参数:
- -h host
- --host= host
-
声明服务器运行的机器的主机名。 如果数值以斜扛开头,那么它被用做 Unix 域套接字的目录。 缺省是从 PGHOST 环境变量中获取的(如果设置了), 否则将尝试进行 Unix 域套接字。 - -p port
- --port= port
-
声明服务器侦听的 TCP 端口或者本地的 Unix 域套接字文件扩展。 缺省是环境变量 PGPORT 的值(如果设置了的话), 否则就说编译的缺省。 - -U username
-
以给出用户身分联接。 - -W
-
强制给出口令提示。如果服务器要求口令认证,那么这个应该自动发生。
ENVIRONMENT 环境
- PGHOST
- PGPORT
- PGUSER
-
缺省连接参数。
DIAGNOSTICS 诊断
当使用 - d 选项声明了直接数据库联接时, pg_restore 在内部执行 SQL 语句。如果你运行 pg_restore 出了毛病, 请确保你能用类似 psql(1) 这样的东西从数据库中选取信息。
NOTES 注意
如果你的安装给 template1 数据库增加了任何你自己的东西, 那么请注意把 pg_dump 的输出恢复到一个真正空的数据库中; 否则你可能会收到因为重复定义所追加的对象而造成的错误信息。要制作一个没有任何本地附属物的数据库, 可以从 template0 而不是 template1 拷贝,比如:
CREATE DATABASE foo WITH TEMPLATE template0;
pg_restore 的局限在下面列出。
- *
-
当向一个已经存在的表恢复数据,并且还使用了 --disable-triggers 选项时, pg_restore 在插入数据前放出一些查询关闭用户表上的触发器, 在数据插入完成后重新打开它们。如果恢复的中途停止,那么系统表可能处于错误状态。 - *
- pg_restore 将不会为单一的表恢复大对象。 如果一个归档包含大对象,那么所有大对象都将被恢复。
又见参阅 pg_dump(1) 的文挡获取有关 pg_dump 的局限的细节。
一旦完成恢复,最好在每个恢复的对象上运行 ANALYZE, 以便给优化器有用的统计。
EXAMPLES 例子
把一个包含大对象的叫 mydb 的数据库转储到一个 tar 文件:
$ pg_dump -Ft -b mydb > db.tar
把这个数据库恢复到现有的叫 newdb 的数据库中(连同 BLOB):
$ pg_restore -d newdb db.tar
要对项目重新排序,首先必须转储归档的目录:
$ pg_restore -l archive.file > archive.list
这个文件由一行头和每个项目一行组成,比如。
;
; Archive created at Fri Jul 28 22:28:36 2000
; dbname: birds
; TOC Entries: 74
; Compression: 0
; Dump Version: 1.4-0
; Format: CUSTOM
;
;
; Selected TOC Entries:
;
2; 145344 TABLE species postgres
3; 145344 ACL species
4; 145359 TABLE nt_header postgres
5; 145359 ACL nt_header
6; 145402 TABLE species_records postgres
7; 145402 ACL species_records
8; 145416 TABLE ss_old postgres
9; 145416 ACL ss_old
10; 145433 TABLE map_resolutions postgres
11; 145433 ACL map_resolutions
12; 145443 TABLE hs_old postgres
13; 145443 ACL hs_old
这里分号是注释分隔符,而行开头的数字代表赋给每个项目的内部归档 ID。
文件内的行可以注释掉,删除和 / 或重新排列。比如,
10; 145433 TABLE map_resolutions postgres
;2; 145344 TABLE species postgres
;4; 145359 TABLE nt_header postgres
6; 145402 TABLE species_records postgres
;8; 145416 TABLE ss_old postgres
可以用做 pg_restore 的输入并且只会恢复项目 10 和 6,(以这个顺序):
$ pg_restore -L archive.list archive.file
关于需要将 mssql 备份文件和.bak 文件导入 postgres的介绍已经告一段落,感谢您的耐心阅读,如果想了解更多关于centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教、Hawq学习笔记 --- postgresql 导入sql文件、pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库、pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。的相关信息,请在本站寻找。
本文标签: