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

22.2. 创建数据库 #

要创建数据库,PostgreSQL服务器必须已经启动并正在运行(见Section 18.3)。

数据库用 SQL 命令CREATE DATABASE创建:

CREATE DATABASE name;

其中name遵循SQL标识符的一般规则。当前角色会自动成为新数据库的拥有者。数据库拥有者有权在日后删除该数据库(这也会删除其中的全部对象,即使那些对象具有不同的拥有者)。

创建数据库是一项受限操作。关于如何授予该权限,见Section 21.2

由于执行CREATE DATABASE命令时必须先连接到数据库服务器,因此还会有一个问题:某个站点上的第一个数据库是如何创建的?第一个数据库总是由initdb命令在初始化数据存储区时创建的(见Section 18.2)。这个数据库叫作postgres因此,要创建第一个普通数据库,可以连接到postgres

在初始化数据库集簇时,还会额外创建两个数据库,即template1template0每当在集簇中创建一个新数据库时,新数据库本质上都是通过克隆template1得到的。这意味着你在template1中所做的任何更改,都会传播到后来创建的所有数据库中。因此,除非你希望这些对象出现在每一个新建数据库中,否则应避免在template1中创建对象。template0则被设计为template1原始内容的一份纯净副本。当需要创建一个不带任何此类站点本地附加对象的数据库时,可以复制它而不是复制template1。更多细节见Section 22.3

为了方便,还可以从 shell 中执行一个程序来创建新数据库,即createdb

createdb dbname

createdb并没有什么特殊之处。它连接到postgres数据库并发出CREATE DATABASE命令,和上面描述的完全一样。关于调用细节见createdb参考页。注意,不带任何参数的createdb会创建一个与当前用户名同名的数据库。

Note

Chapter 20包含关于如何限制谁能连接到给定数据库的信息。

有时你会想为其他人创建数据库,并让他们成为新数据库的拥有者,以便他们自行配置和管理它。要实现这一点,可使用下列命令之一:

CREATE DATABASE dbname OWNER rolename;

这是在 SQL 环境中使用;或者:

createdb -O rolename dbname

这是在 shell 中使用。只有超级用户才允许为其他人(即为一个你不是其成员的角色)创建数据库。

提交更正

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