PostgreSQLでデータベースのスキーマをエクスポートするにはどうすればよいですか?


111

コンピュータが故障したが、幸いにもC:\ Program Files \ PostgreSQLフォルダをバックアップした。

今、私は新しいコンピュータで作業しています。外部ディスクに保存されている以前のPostgresデータベースをインポートしたいと思います。

バックアップフォルダーにある特定のデータベースのスキーマをエクスポートしたいと思います。

このファイルにPostgreSQL\8.3\data\global\pg_databaseは、データベースとそのOIDに関する情報が含まれています。例えば:

"db1" 20012
"db2" 23456

「db1」のスキーマをエクスポートしたい。

"PostgreSQL\8.3\data\base\20012" 大量のファイル[500ファイル]を含むフォルダに「20012」という名前のフォルダがあります。

そのデータベースのスキーマをエクスポートする方法はありますか?

すべてのPostgresqlデータベースファイルが外部ハードディスクに配置されていることに注意してください。そのデータベースのスキーマをSQLファイルにエクスポートし、そのファイルを取得して実行し、まったく同じデータベースをローカルに作成します。

回答:


141

あなたは見てみる必要がありますpg_dump

pg_dump -s databasename

スキーマのみを.sqlとしてstdoutにダンプします。

Windowsの場合は、を呼び出しますpg_dump.exe。私はWindowsマシンにアクセスできませんが、メモリからコマンドだと確信しています。ヘルプもあなたのために働くかどうかを確認してください。


pg_dumpが機能することを確信していますか?データベースのファイルがローカルではなく外部ディスクに配置されているため
プログラマー、

古いデータベースサーバーを起動できる場合は、そうです。pg_dumpは、おそらくご存じのとおり、データベースサーバーにリモートで接続できます。新しいマシンに8.3をインストールして古いデータベースファイルをコピーし、postgresを起動して、それが機能するかどうかを確認します。スキーマのみをダンプすることについてもっと一般的に質問していると思いました。
2013年

postgresqlの8.3バージョンをすでにインストールし、dataフォルダーを新しいインストールにコピーしましたが、古いデータベースが表示されません...
プログラマー

14
@改めて感謝します。pg_dump -s databasename > schema.sql結果をschema.sqlファイルに出力します
Arivarasan L 2015

この場合のカスタムデータ型はどうですか?
Nikita

38

ではLinuxでは、あなたは次のように行うことができます

pg_dump -U postgres -s postgres > exportFile.dmp

pg_dump.exeで同じようにしないと、Windowsでも機能する可能性があります

pg_dump.exe -U postgres -s postgres > exportFile.dmp

pg_dump:[archiver(db)]データベース "goldendemon"への接続に失敗しました:無効なポート番号: "-s"
Jamie Hutber

33

Postgres 9.6を実行していますが、データとともに特定のスキーマをエクスポートする必要がありました。

次のコマンドを使用しました。

pg_dump.exe -U username -d databasename -n schemaname > C:\mylocation\mydumpfilename.dmp

データなしのスキーマのみが必要な場合は、s代わりにスイッチを使用しますn

以下はpg_dumpスイッチリストです。

C:\Program Files\PostgreSQL\9.6\bin>pg_dump --help
pg_dump dumps a database as a text file or to other formats.

Usage:
  pg_dump [OPTION]... [DBNAME]

General options:
  -f, --file=FILENAME          output file or directory name
  -F, --format=c|d|t|p         output file format (custom, directory, tar,
                               plain text (default))
  -j, --jobs=NUM               use this many parallel jobs to dump
  -v, --verbose                verbose mode
  -V, --version                output version information, then exit
  -Z, --compress=0-9           compression level for compressed formats
  --lock-wait-timeout=TIMEOUT  fail after waiting TIMEOUT for a table lock
  -?, --help                   show this help, then exit

Options controlling the output content:
  -a, --data-only              dump only the data, not the schema
  -b, --blobs                  include large objects in dump
  -c, --clean                  clean (drop) database objects before recreating
  -C, --create                 include commands to create database in dump
  -E, --encoding=ENCODING      dump the data in encoding ENCODING
  -n, --schema=SCHEMA          dump the named schema(s) only
  -N, --exclude-schema=SCHEMA  do NOT dump the named schema(s)
  -o, --oids                   include OIDs in dump
  -O, --no-owner               skip restoration of object ownership in
                               plain-text format
  -s, --schema-only            dump only the schema, no data
  -S, --superuser=NAME         superuser user name to use in plain-text format
  -t, --table=TABLE            dump the named table(s) only
  -T, --exclude-table=TABLE    do NOT dump the named table(s)
  -x, --no-privileges          do not dump privileges (grant/revoke)
  --binary-upgrade             for use by upgrade utilities only
  --column-inserts             dump data as INSERT commands with column names
  --disable-dollar-quoting     disable dollar quoting, use SQL standard quoting
  --disable-triggers           disable triggers during data-only restore
  --enable-row-security        enable row security (dump only content user has
                               access to)
  --exclude-table-data=TABLE   do NOT dump data for the named table(s)
  --if-exists                  use IF EXISTS when dropping objects
  --inserts                    dump data as INSERT commands, rather than COPY
  --no-security-labels         do not dump security label assignments
  --no-synchronized-snapshots  do not use synchronized snapshots in parallel jobs
  --no-tablespaces             do not dump tablespace assignments
  --no-unlogged-table-data     do not dump unlogged table data
  --quote-all-identifiers      quote all identifiers, even if not key words
  --section=SECTION            dump named section (pre-data, data, or post-data)
  --serializable-deferrable    wait until the dump can run without anomalies
  --snapshot=SNAPSHOT          use given snapshot for the dump
  --strict-names               require table and/or schema include patterns to
                               match at least one entity each
  --use-set-session-authorization
                               use SET SESSION AUTHORIZATION commands instead of
                               ALTER OWNER commands to set ownership

Connection options:
  -d, --dbname=DBNAME      database to dump
  -h, --host=HOSTNAME      database server host or socket directory
  -p, --port=PORT          database server port number
  -U, --username=NAME      connect as specified database user
  -w, --no-password        never prompt for password
  -W, --password           force password prompt (should happen automatically)
  --role=ROLENAME          do SET ROLE before dump

If no database name is supplied, then the PGDATABASE environment
variable value is used.

Report bugs to <pgsql-bugs@postgresql.org>.

11
pg_dump -d <databasename> -h <hostname> -p <port> -n <schemaname> -f <location of the dump file>

そのスキーマにアクセスするための十分な権限があることに注意してください。特定のユーザーとしてバックアップを取得する場合は、そのコマンドの前にユーザー名を追加します-U


1
pg_dump -s <データベース名> -h <ホスト名> -p <ポート> -n <スキーマ名> -f <ダンプファイルの場所>スキーマのみを取得するには、フラグを-dから-sに変更します。これは、このansを改善するためだけのものであり、他の人々も言及しています。
h0lmes221B

これはDB全体を使用します:/
Jamie Hutber

7

作成テーブルのみが必要な場合は、次のことができます pg_dump -s databasename | awk 'RS="";/CREATE TABLE[^;]*;/'


3

以下のためのLinux: (データは除外)

  • pg_dump -s -t tablename databasename > dump.sql (データベース内の特定のテーブルの場合)

  • pg_dump -s databasename > dump.sql (データベース全体)


2

新しいpostgresqlサーバーをセットアップし、そのデータフォルダーを外部ディスクのファイルで置き換えます。

その後、そのpostgresqlサーバーを起動し、pg_dumpを使用してデータを取得できます(前述のようにスキーマのみの場合はpg_dump -s)。


データフォルダーを古いものに置き換えてから、サービスを開始し、pgAdmin IIIアプリケーションを開いて、サーバーアイコンをクリックしました(前のサーバーは1つしかありませんでした)。新しいサーバーを作成しましょうか?動作しないので...最初に作成したデータベースがまだ表示されます...バックアップデータベースは表示されません
プログラマー

ファイルを正しいデータフォルダにポップしましたか?私はWindowsでpostgresqlを使用していないため、データフォルダーがどこにあるかわかりません。また、pgAdminが何かをキャッシュするので、再接続する必要があるかどうかも
わかり

C:\ Program Files \ PostgreSQL \ 8.3にある古いバックアップデータファイルをコピーして、新しいものに置き換えました。また、もう一度pgAdminを開くと、古いコンピューターのパスワードを要求されます。これは良い兆候ですが、その後データベースツリーにデータベースが表示されません
プログラマー

ええと...「db1」というデータベースを作成しました[古いコンピュータのデータベース]をクリックすると、pgAdminが「エラーが発生しました:データベース20012の致命的なキャッシュルックアップに失敗しました」と出力します。それはどういう意味ですか?
プログラマー

1
pgAdminは多くの情報をキャッシュしているようです。pgAdminでデータベース接続をドロップして、再作成します。問題がキャッシュに関連している場合は、これで解決します...
drone.ah 2013年

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.