企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
# CREATE DATABASE ## Name CREATE DATABASE -- 创建一个新数据库 ## Synopsis ``` CREATE DATABASE _name_ [ [ WITH ] [ OWNER [=] _user_name_ ] [ TEMPLATE [=] _template_ ] [ ENCODING [=] _encoding_ ] [ LC_COLLATE [=] _lc_collate_ ] [ LC_CTYPE [=] _lc_ctype_ ] [ TABLESPACE [=] _tablespace_name_ ] [ CONNECTION LIMIT [=] _connlimit_ ] ] ``` ## 描述 `CREATE DATABASE`创建一个新PostgreSQL数据库。 要创建一个数据库,你必须是一个超级用户或者有特殊的`CREATEDB`权限。 参阅[CREATE USER](#calibre_link-15)。 缺省情况下新数据库将通过复制标准系统数据库`template1`来创建。 可以通过`TEMPLATE` `_name_`指定不同的模板。 尤其是,用`TEMPLATE template0`创建一个很纯净的、 只包括PostgreSQL预定义的标准对象的数据库。 这个方法对于避免把任何已经加入到`template1`里的本地安装对象拷贝到新数据库是非常有用的。 ## 参数 `_name_` 要创建的数据库名字。 `_user_name_` 数据库用户的名字,他将是新数据库的所有者,或者是使用`DEFAULT`选项来指定当前缺省用户(也就是执行命令的用户)。 要创建一个其他角色所有的数据库,你必须是那个角色的直接或间接的成员,或者是超级用户。 `_template_` 模板名,即从哪个模板创建新数据库,或者使用`DEFAULT`选项来指定缺省模板(`template1`)。 `_encoding_` 创建新数据库使用的字符编码。 可以使用文本名字(例如`'SQL_ASCII'`)、整数编号或是`DEFAULT`选项来指定(模版数据库的编码)。 PostgreSQL服务器支持的字符集在[Section 22.3.1](#calibre_link-1463)里有描述。 额外的限制参见下文。 `_lc_collate_` 用于新数据库的排序规则(LC_COLLATE)。 这影响到应用对字符串的排序顺序,例如:在有ORDER BY的查询中,以及用于文本列的索引的顺序。 在默认情况下,使用模板数据库的排序规则。 请看以下附加的限制。 `_lc_ctype_` 用于新数据库的字符分类(`LC_CTYPE`)。 这影响字符的分类,例如: 小写、大写和数字。 默认情况下使用模板数据库的字符分类。 请看以下附加的限制。 `_tablespace_name_` 和新数据库关联的表空间名字, 或者使用`DEFAULT`选项表示使用模版数据库的表空间。 这个表空间将成为在这个数据库里创建的对象的缺省表空间。 参阅[CREATE TABLESPACE](#calibre_link-99)获取更多信息。 `_connlimit_` 数据库可以接受多少并发的连接。-1(缺省)意味着没有限制。 可选参数可以按任意顺序书写,而不仅仅是上面显示的顺序。 ## 注意 `CREATE DATABASE`不能在事务块里面执行。 类似"could not initialize database directory"这样的错误,最有可能是因为数据目录的权限不够或者磁盘满之类的文件系统问题。 使用[DROP DATABASE](#calibre_link-38)删除一个数据库。 程序[createdb](#calibre_link-40)是这个命令的封装,使用更加方便。 尽管可以通过把某数据库名声明为模板而不是用`template1`,但是这(还)不是一个通用的"`COPY DATABASE`"功能。 主要的限制是在从模版复制的时候不允许有其它会话链接到模版数据库上。 如果在开始执行`CREATE DATABASE`的时候有其它会话正连接在模版数据库上,那么操作将会失败; 否则直到`CREATE DATABASE`完成之后,才允许对模板数据库建立新的会话连接。 参见[Section 21.3](#calibre_link-1266)获取更多信息。 为一个新数据库指定的字符集编码必须兼容所选择的区域环境设置 (`LC_COLLATE`和`LC_CTYPE`)。 若区域设置为 `C`(或相当于`POSIX`),那么所有的编码都允许, 但是对于其他的区域设置,只有一个编码能正常工作。 (然而,在Windows系统中, UTF-8编码可用于任何区域设置。) `CREATE DATABASE`将会允许超级用户 来指定`SQL_ASCII`编码而不考虑区域设置情况,这种做法已过时了,是不宜采用的,它会导致编码与不兼容区域设置的数据被存储在数据库中时字符串函数功能会不正常。 除了`template0`用作模板的时候,其他数据库的编码和区域设置必须匹配模板数据库。 这是因为其他数据库可能会包含不匹配指定编码的数据,或者可能包含排序顺序受`LC_COLLATE`和`LC_CTYPE`影响的索引。 复制这些数据会导致数据库被新设置破坏。 然而,`template0`公认是不包含任何会受到影响的数据或者索引的。 `CONNECTION LIMIT`选项只是近似地强制;如果两个新的连接几乎同时发起, 而只剩下一个连接"slot"了,那么很可能两个连接都失效。另外,超级用户连接时不受这个限制。 ## 例子 创建一个新数据库: ``` CREATE DATABASE lusiadas; ``` 创建一个由用户`salesapp`拥有的数据库`sales`,缺省表空间是`salesspace`: ``` CREATE DATABASE sales OWNER salesapp TABLESPACE salesspace; ``` 创建一个数据库`music`,支持ISO-8859-1字符集: ``` CREATE DATABASE music ENCODING 'LATIN1' TEMPLATE template0; ``` 在这个例子中,`TEMPLATE template0`选项只在`template1`的编码不是ISO-8859-1时被请求。 请注意:更改编码可能也会需要选择新的`LC_COLLATE`和`LC_CTYPE`设置。 ## 兼容性 在sql标准里头没有 CREATE DATABASE 语句。数据库等同于目录,其创建是交给具体的数据库实现去定义的。 ## 参见 [ALTER DATABASE](#calibre_link-1431), [DROP DATABASE](#calibre_link-38)