CREATE DATABASE

    注意事项

    • 只有拥有CREATEDB权限的用户才可以创建新数据库,系统管理员默认拥有此权限。
    • 不能在事务块中执行创建数据库语句。
    • 在创建数据库过程中,出现类似“Permission denied”的错误提示,可能是由于文件系统上数据目录的权限不足。出现类似“No space left on device”的错误提示,可能是由于磁盘满引起的。

    参数说明

    • database_name

      数据库名称。

      取值范围:字符串,要符合标识符的命名规范。

    • OWNER [ = ] user_name

      数据库所有者。缺省时,新数据库的所有者是当前用户。

      取值范围:已存在的用户名。

    • TEMPLATE [ = ] template

      模板名。即从哪个模板创建新数据库。openGauss采用从模板数据库复制的方式来创建新的数据库。初始时,openGauss包含两个模板数据库template0、template1,以及一个默认的用户数据库postgres。

      取值范围:仅template0。

    • ENCODING [ = ] encoding

      指定数据库使用的字符编码,可以是字符串(如’SQL_ASCII’)、整数编号。

      不指定时,默认使用模版数据库的编码。模板数据库template0和template1的编码默认与操作系统环境相关。template1不允许修改字符编码,因此若要变更编码,请使用template0创建数据库。

      常用取值:GBK、UTF8、Latin1。

      表 1 openGauss字符集

    • LC_COLLATE [ = ] lc_collate

      指定新数据库使用的字符集。例如,通过lc_collate = ‘zh_CN.gbk’设定该参数。

      该参数的使用会影响到对字符串的排序顺序(如使用ORDER BY执行,以及在文本列上使用索引的顺序)。默认是使用模板数据库的排序顺序。

      取值范围:有效的排序类型。

    • LC_CTYPE [ = ] lc_ctype

      指定新数据库使用的字符分类。例如,通过lc_ctype = ‘zh_CN.gbk’设定该参数。该参数的使用会影响到字符的分类,如大写、小写和数字。默认是使用模板数据库的字符分类。

      取值范围:有效的字符分类。

    • DBCOMPATIBILITY [ = ] compatibility_type

      指定兼容的数据库的类型,默认兼容O。

      取值范围:A、B、C、PG。分别表示兼容O、MY、TD和POSTGRES。

    • TABLESPACE [ = ] tablespace_name

      指定数据库对应的表空间。

      取值范围:已存在表空间名。

    • CONNECTION LIMIT [ = ] connlimit

      数据库可以接受的并发连接数。

      取值范围:>=-1的整数。默认值为-1,表示没有限制。

    有关字符编码的一些限制:

    • 若区域设置为C(或POSIX),则允许所有的编码类型,但是对于其他的区域设置,字符编码必须和区域设置相同。
    • 若字符编码方式是SQL_ASCII,并且修改者为管理员用户时,则字符编码可以和区域设置不相同。
    • 编码和区域设置必须匹配模板数据库,除了将template0当作模板。 因为其他数据库可能会包含不匹配指定编码的数据,或者可能包含排序顺序受LC_COLLATE和LC_CTYPE影响的索引。复制这些数据会导致在新数据库中的索引失效。template0是不包含任何会受到影响的数据或者索引。
    1. openGauss=# CREATE USER jim PASSWORD 'xxxxxxxxx';
    2. openGauss=# CREATE USER tom PASSWORD 'xxxxxxxxx';
    3. --创建一个GBK编码的数据库music(本地环境的编码格式必须也为GBK)。
    4. openGauss=# CREATE DATABASE music ENCODING 'GBK' template = template0;
    5. --创建数据库music2,并指定所有者为jim
    6. openGauss=# CREATE DATABASE music2 OWNER jim;
    7. --用模板template0创建数据库music3,并指定所有者为jim
    8. openGauss=# CREATE DATABASE music3 OWNER jim TEMPLATE template0;
    9. --设置music数据库的连接数为10
    10. openGauss=# ALTER DATABASE music CONNECTION LIMIT= 10;
    11. openGauss=# ALTER DATABASE music RENAME TO music4;
    12. --将数据库music2的所属者改为tom
    13. openGauss=# ALTER DATABASE music2 OWNER TO tom;
    14. --设置music3的表空间为PG_DEFAULT
    15. --关闭在数据库music3上缺省的索引扫描。
    16. openGauss=# ALTER DATABASE music3 SET enable_indexscan TO off;
    17. --重置enable_indexscan参数。
    18. openGauss=# ALTER DATABASE music3 RESET enable_indexscan;
    19. --删除数据库。
    20. openGauss=# DROP DATABASE music3;
    21. openGauss=# DROP DATABASE music4;
    22. --删除jimtom用户。
    23. openGauss=# DROP USER jim;
    24. openGauss=# DROP USER tom;
    25. --创建兼容TD格式的数据库。
    26. openGauss=# CREATE DATABASE td_compatible_db DBCOMPATIBILITY 'C';
    27. --创建兼容A格式的数据库。
    28. openGauss=# CREATE DATABASE ora_compatible_db DBCOMPATIBILITY 'A';
    29. --删除兼容TDA格式的数据库。
    30. openGauss=# DROP DATABASE td_compatible_db;

    相关链接

    ALTER DATABASE

    • create database

      事务中不支持创建database。