PostgreSQL在哪里存储数据库?

PostgreSQL数据库的文件存储在哪里?

520260 次浏览

在我的Linux安装中,它在这里:/var/lib/postgresql/8.x/

你可以用initdb -D "c:/mydb/"来改变它

特定表/索引的位置可以通过TABLESPACEs进行调整:

CREATE TABLESPACE dbspace LOCATION '/data/dbs';
CREATE TABLE something (......) TABLESPACE dbspace;
CREATE TABLE otherthing (......) TABLESPACE dbspace;

在Windows上,PostgresSQL文档描述所在的PGDATA目录位于C:\Program Files\PostgreSQL\8.1\data之类的地方。特定数据库的数据在(例如)C:\Program Files\PostgreSQL\8.1\data\base\100929下,我猜100929是数据库号。

在Mac上:/Library/PostgreSQL/9.0/data/base

目录不能被输入,但是你可以通过:sudo du -hc data查看内容

要查看数据目录的位置,请使用此查询。

show data_directory;

要查看所有运行时参数,请使用

show all;

您可以创建表空间来在文件系统的其他部分存储数据库对象。要查看可能不在该数据目录中的表空间,请使用此查询。

SELECT *, pg_tablespace_location(oid) FROM pg_tablespace;

在Windows7上,所有数据库都是由C:\Program Files (x86)\PostgreSQL\8.2\data\global下名为pg_database的文件中的一个数字引用的。然后,您应该在C:\Program Files (x86)\PostgreSQL\8.2\data\base下通过该数字搜索文件夹名称。这就是数据库的内容。

打开pgAdmin,进入特定数据库的属性。找到OID,然后打开目录

<POSTGRESQL_DIRECTORY>/data/base/<OID>

这里应该有您的DB文件。

正如“PostgreSQL数据库在Linux上的默认位置”所建议的,在Linux下,您可以使用以下命令找到:

ps aux | grep postgres | grep -- -D

Postgres将数据存储在其数据目录中的文件中。按照以下步骤进入数据库及其文件:

postgresql表文件对应的数据库是目录。整个数据目录的位置可以通过运行SHOW data_directory来获得。 在UNIX类OS(例如:Mac) /Library/PostgreSQL/9.4/data 进入data目录中的base文件夹,其中包含所有数据库文件夹:/Library/PostgreSQL/9.4/data/base

通过运行(给出一个整数。这是数据库文件夹名):

SELECT oid from pg_database WHERE datname = <database_name>;

通过运行(给出一个整数。这是文件名):

SELECT relname, relfilenode FROM pg_class WHERE relname = <table_name>;

这是一个二进制文件。可以像往常一样获得文件的详细信息,如大小和创建日期时间。有关更多信息读取这个SO线程

我敢打赌你问这个问题是因为你已经尝试过pg_ctl start并收到以下错误:

pg_ctl:未指定数据库目录,环境变量PGDATA未设置

换句话说,你在pg_ctl start命令中寻找要放在-D后面的目录。

在本例中,您要查找的目录包含这些文件。

PG_VERSION      pg_dynshmem     pg_multixact
pg_snapshots    pg_tblspc       postgresql.conf
base            pg_hba.conf     pg_notify
pg_stat         pg_twophase     postmaster.opts
global          pg_ident.conf   pg_replslot
pg_stat_tmp     pg_xlog         postmaster.pid
pg_clog         pg_logical      pg_serial
pg_subtrans     postgresql.auto.conf    server.log

您可以通过使用操作系统提供的搜索来定位上面的任何文件和目录来定位它。

例如,在我的例子中(在Mac OS X上安装家酿),这些文件位于/usr/local/var/postgres。要启动服务器,我输入:

pg_ctl -D /usr/local/var/postgres -w start

... 这很有效。

每个人都已经回答了,但只是最新的更新。如果您想知道所有配置文件的位置,那么在shell中运行这个命令

SELECT name, setting FROM pg_settings WHERE category = 'File Locations';

Picmate的答案是正确的。在windows上,主DB文件夹的位置是(至少在我的安装)

C:\PostgreSQL\9.2\data\base\

而且不是在程序文件中。

他的2个脚本,将给你确切的目录/文件(s)你需要:

SELECT oid from pg_database WHERE datname = <database_name>;
SELECT relname, relfilenode FROM pg_class WHERE relname = <table_name>;

我的在datname 16393和relfilenode 41603中

database files in postgresql

我在docker容器中运行postgres(9.5)(在CentOS上,碰巧),正如Skippy le Grand Gourou在上面的注释中提到的,文件位于/var/lib/postgresql/data/中。

$ docker exec -it my-postgres-db-container bash
root@c7d61efe2a5d:/# cd /var/lib/postgresql/data/
root@c7d61efe2a5d:/var/lib/postgresql/data# ls -lh
total 56K
drwx------. 7 postgres postgres   71 Apr  5  2018 base
drwx------. 2 postgres postgres 4.0K Nov  2 02:42 global
drwx------. 2 postgres postgres   18 Dec 27  2017 pg_clog
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_commit_ts
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_dynshmem
-rw-------. 1 postgres postgres 4.4K Dec 27  2017 pg_hba.conf
-rw-------. 1 postgres postgres 1.6K Dec 27  2017 pg_ident.conf
drwx------. 4 postgres postgres   39 Dec 27  2017 pg_logical
drwx------. 4 postgres postgres   36 Dec 27  2017 pg_multixact
drwx------. 2 postgres postgres   18 Nov  2 02:42 pg_notify
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_replslot
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_serial
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_snapshots
drwx------. 2 postgres postgres    6 Sep 16 21:15 pg_stat
drwx------. 2 postgres postgres   63 Nov  8 02:41 pg_stat_tmp
drwx------. 2 postgres postgres   18 Oct 24  2018 pg_subtrans
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_tblspc
drwx------. 2 postgres postgres    6 Dec 27  2017 pg_twophase
-rw-------. 1 postgres postgres    4 Dec 27  2017 PG_VERSION
drwx------. 3 postgres postgres   92 Dec 20  2018 pg_xlog
-rw-------. 1 postgres postgres   88 Dec 27  2017 postgresql.auto.conf
-rw-------. 1 postgres postgres  21K Dec 27  2017 postgresql.conf
-rw-------. 1 postgres postgres   37 Nov  2 02:42 postmaster.opts
-rw-------. 1 postgres postgres   85 Nov  2 02:42 postmaster.pid

一个终端命令:pg_lsclusters,(使用Ubuntu)

你需要的是在数据目录下:

Ver Cluster Port Status Owner    Data directory               Log file
10  main    5432 online postgres /var/lib/postgresql/10/main  /var/log/postgresql/postgresql-10-main.log
11  main    5433 online postgres /var/lib/postgresql/11/main  /var/log/postgresql/postgresql-11-main.log