受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

createdb

createdb — 创建新的PostgreSQL数据库

Synopsis

createdb [connection-option...] [option...] [dbname [description]]

描述

createdb创建一个新的PostgreSQL数据库。

通常,执行此命令的数据库用户会成为新数据库的所有者。不过,如果执行用户具有相应的权限,也可以通过-O选项指定不同的所有者。

createdbSQL命令CREATE DATABASE的一个包装器。通过该工具创建数据库,与通过其他访问服务器的方法创建数据库在实际效果上没有区别。

选项

createdb接受下列命令行参数:

dbname #

指定要创建的数据库名称。该名称必须在此数据库集簇中的所有PostgreSQL数据库中唯一。 默认情况下,会创建一个与当前系统用户同名的数据库。

description #

指定要与新创建的数据库关联的注释。

-D tablespace
--tablespace=tablespace #

指定数据库的默认表空间。(该名称将按双引号标识符处理。)

-e
--echo #

回显createdb生成并发送到服务器的命令。

-E encoding
--encoding=encoding #

指定该数据库使用的字符集编码。PostgreSQL服务器支持的字符集见Section 23.3.1

-l locale
--locale=locale #

指定该数据库要使用的区域设置。这等同于为--lc-collate--lc-ctype--icu-locale指定相同的值。 某些区域设置仅对 ICU 有效,必须通过--icu-locale设置。

--lc-collate=locale #

指定该数据库要使用的 LC_COLLATE 设置。

--lc-ctype=locale #

指定该数据库要使用的 LC_CTYPE 设置。

--builtin-locale=locale #

当使用 builtin 提供程序时,指定区域设置名称。区域设置支持的说明见 Section 23.1

--icu-locale=locale #

如果选择了 ICU 区域设置提供程序,则指定该数据库要使用的 ICU 区域设置 ID。

--icu-rules=rules #

指定附加的排序规则,用以定制该数据库默认排序规则的行为。该选项仅支持 ICU。

--locale-provider={builtin|libc|icu} #

指定数据库默认排序规则所使用的区域设置提供程序。

-O owner
--owner=owner #

指定将成为新数据库拥有者的数据库用户。 (该名称按双引号标识符处理。)

-S strategy
--strategy=strategy #

指定数据库创建策略。详见CREATE DATABASE STRATEGY

-T template
--template=template #

指定用于构建该数据库的模板数据库。(该名称按双引号标识符处理。)

-V
--version #

打印createdb的版本并退出。

-?
--help #

显示有关createdb命令行参数的帮助信息,并退出。

选项-D-l-E-O-T对应于底层 SQL 命令CREATE DATABASE的选项;有关这些选项的更多信息请参阅该命令。

createdb也接受下列与连接参数有关的命令行参数:

-h host
--host=host #

指定服务器所在机器的主机名。如果该值以斜杠开头,则它将被用作 Unix 域套接字的目录。

-p port
--port=port #

指定服务器监听连接所用的 TCP 端口或本地 Unix 域套接字文件扩展名。

-U username
--username=username #

以该用户名进行连接。

-w
--no-password #

从不发出密码提示。如果服务器要求密码认证,而密码又无法通过诸如.pgpass文件等其他方式获得,则连接尝试将失败。该选项适合没有用户在场输入密码的批处理作业和脚本。

-W
--password #

强制createdb在连接到数据库之前提示输入密码。

这个选项并非必不可少,因为如果服务器要求密码认证,createdb会自动提示输入密码。不过,createdb会浪费一次连接尝试,才知道服务器需要密码。在某些情况下,为了避免这次额外的连接尝试,提前指定-W是值得的。

--maintenance-db=dbname #

指定在创建新数据库时要连接到的数据库名称。如果未指定,将使用postgres数据库;若该数据库不存在(或者它正是要创建的新数据库),则改用template1。 这也可以是一个连接字符串。如果是这种情况,其中的连接字符串参数将覆盖任何冲突的命令行选项。

环境

PGDATABASE #

如果设置了该变量,其值就是要创建的数据库名称,除非被命令行覆盖。

PGHOST
PGPORT
PGUSER #

默认连接参数。如果命令行和PGDATABASE都没有指定要创建的数据库名称,则PGUSER也会决定该名称。

PG_COLOR #

指定是否在诊断消息中使用颜色。可能的值为alwaysautonever

与大多数其他PostgreSQL工具一样,该工具也使用libpq支持的环境变量(见Section 32.15)。

诊断

如果遇到问题,请参阅CREATE DATABASEpsql中关于潜在问题和错误消息的讨论。数据库服务器必须在目标主机上运行。此外,由libpq前端库使用的任何默认连接设置和环境变量也都会生效。

示例

要使用默认数据库服务器创建demo数据库:

$ createdb demo

要使用主机eden上、端口为 5000 的服务器,并以template0作为模板数据库来创建demo数据库,可使用以下命令行命令及其底层 SQL 命令:

$ createdb -p 5000 -h eden -T template0 -e demo
CREATE DATABASE demo TEMPLATE template0;

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。