#CREATE DATABASE
# 通用描述
CREATE DATABASE用于创建一个新的数据库,该语句只能在一个处于NOMOUNT状态的空实例(Instance)中执行。系统通过本语句成功创建新数据库后,同时将其启动至OPEN状态。
单机部署中,使用CREATE DATABASE语句创建一个新的单实例数据库,数据库文件路径仅支持指定为本地文件系统路径。
分布式部署中,通过yasboot安装过程中即在所有的分布式节点上依据配置文件中指定参数创建数据库,后续不再允许在某个节点上执行本语句(除非用于故障恢复),否则将导致分布式集群出现节点不一致情况。
共享集群部署中,必须使用CREATE CLUSTER DATABASE创建一个新的多实例数据库,且redo、undo、swap等所有数据文件须指定为YFS路径,否则返回错误。
创建数据库的过程中会在指定或默认位置创建物理文件,如过程中出现任何异常导致创建数据库失败时,这些已创建的文件将残留,用户需进行手动清理,未清理且使用相同文件再次CREATE DATABASE时将失败。
# 语句定义
create database::=
create_single_instance_database::=
create_multiple_instance_database::=
# create_single_instance_database
该语句用于创建一个单实例的数据库。
# database_name
指定要创建的数据库的名称,不可省略,且需符合YashanDB的对象命名规范。
# attribute_clause
该语句用来指定创建数据库的配置。
# user sys identified by
该语句用于指定SYS用户的口令,可省略,则数据库创建后SYS用户的口令仍为初始值,并可通过ALTER USER语句并更口令。
# controlfiles
该语句用于指定创建数据库时,同时创建的控制文件,多个控制文件用,
分隔,可省略,则系统根据CONTROL_FILES参数定义的默认值在磁盘上生成控制文件。YashanDB支持指定最多8个控制文件。
# maxdatafiles
该语句用于指定数据库能打开的数据文件的最大个数,该值决定了控制文件里Datafile Section所占的初始空间,可省略,则取系统默认值4096。YashanDB支持指定的最大值为16384。
# maxdatabuckets
该语句用于指定数据库能挂载的databucket的最大个数,可省略,则取系统默认值256。YashanDB支持指定的最大值为4096。
# maxinstances
该语句用于指定能同时挂载(Mount)该数据库的最大实例个数,可省略,则取系统默认值8。YashanDB支持指定的最大值为64。
# character set
该语句用于指定数据库存储数据到文件所使用的字符集,可省略,则取系统默认值UTF8。YashanDB支持指定的字符集有ASCII、GBK、UTF8、ISO8859-1、GB18030。
如需使用TAC表和LSC表,数据库的字符集必须设置为UTF8。
# national character set
该语句用于指定数据库使用的国家字符集,可省略,则取系统默认值UTF16。YashanDB支持指定的国家字符集仅有UTF16。
# undo_segments
该语句用于指定数据库可自动扩展回滚段的最大个数,可省略,则为默认值64。YashanDB支持指定的最大值为256。
# maxlogfiles
该语句用于指定redo日志文件的元数据预留个数,该值决定了控制文件里Redofile Section所占的初始空间,可省略,则取系统默认值256,YashanDB支持指定的最大值为4096。该值不限制实例可创建的redo日志文件个数,当创建的redo日志个数超过该值时,控制文件可能会扩展。
# maxloghistory
该语句用于指定归档日志文件的元数据预留个数,该值决定了控制文件里Archfile Section所占的初始空间,可省略,则取系统默认值64000。YashanDB支持指定的最大值为1000000。该值不限制实例可创建的归档日志文件个数,当创建的归档日志个数超过该值时,控制文件可能会扩展。
# archivelog|noarchivelog
该语句用于指定数据库是否开启归档模式,可省略,则取系统默认值NOARCHIVELOG。
# double_write datafile dbwfile size size_clause
该语句用于指定创建数据库时,同时创建的双写文件的路径和大小,可省略,则在系统默认的数据文件路径下创建一个名称为dwf,大小为8192个BLOCK的文件。
当指定创建双写文件时文件过小会出现建库失败,双写文件的可用最小值受配置参数DBWR_BUFFER_SIZE和DBWR_COUNT影响,最小值近似公式:4 * DBWR_BUFFER_SIZE * DBWR_COUNT + 4M。
# logfile logfiles_clause
该语句用于指定创建数据库时,同时创建的redo日志文件的路径和大小,可省略,则在系统默认的数据文件路径下创建三个名称为redo1/redo2/redo3,大小为128M,BLOCKSIZE为4K的文件。
# logfiles_clause
logfile:日志文件的名称,未包含路径时,取系统默认的数据文件路径。
SIZE:日志文件的大小。
BLOCKSIZE:日志文件的页面大小。默认是4K,最小512字节,最大32K。其值一般设置为操作系统BLOCK的大小,小于系统BLOCK大小的话,会有性能影响。一般不建议修改。
# tablespace_clause
创建数据库时会同时创建内置表空间,包括SYSTEM表空间、SYSAUX表空间、UNDO表空间、SWAP表空间、TEMP表空间(TEMPORARY)、USERS表空间(DEFAULT)以及USERS_AIM表空间(仅存在于分布式部署)。
该语句用于指定内置表空间的各项属性,可省略,省略则系统按下面各项给出的缺省值创建内置表空间。
# tempfile|datafile
表空间对应的数据文件类型,其中SWAP表空间和TEMP表空间的数据文件类型缺省为TEMPFILE,其他表空间缺省为DATAFILE。
# datafiles_clause
表空间对应的数据文件名称,多个数据文件用,
分隔。缺省在系统默认的数据文件路径下创建名称与表空间名称相同(DEFAULT表空间对应的数据文件名默认为users),大小为8192个BLOCK,开启自动扩展,每次扩展8192个BLOCK,最大可扩展到64MB个BLOCK(UNDO表空间为8MB个BLOCK)的数据文件。
# extent_clause
表空间对象申请extent时的空间分配方式,AUTOALLOCATE分配方式根据对象当前大小由系统自动分配extent空间,UNIFORM分配方式每次为对象分配的extent空间为固定值。
UNDO表空间、SWAP表空间不允许指定extent分配方式,只能使用UNIFORM分配方式,默认为UNIFORM SIZE 1个BLOCK。
TEMP表空间若不指定分配方式,默认为UNIFORM SIZE 8个BLOCK。
其它内置表空间默认为AUTOALLOCATE(系统自动分配)。
# memory mapped
指定是否启用数据常驻内存模式,默认不启用。
# databucket_clause
当为表空间指定了DATABUCKET时,系统将按指定路径信息创建用于对象存储的目录。对于DEFAULT表空间,如未指定DATABUCKET,系统将在默认路径(local_fs)下创建users文件夹用于对象存储。
示例(单机部署)
CREATE DATABASE yashan
CHARACTER SET utf8
NATIONAL CHARACTER SET utf16
ARCHIVELOG
LOGFILE ('/home/yasdb/YASDB_DATA/dbfiles/redo1' size 2G BLOCKSIZE 512,
'/home/yasdb/YASDB_DATA/dbfiles/redo2' size 2G BLOCKSIZE 512,
'/home/yasdb/YASDB_DATA/dbfiles/redo3' size 2G BLOCKSIZE 512,
'/home/yasdb/YASDB_DATA/dbfiles/redo4' size 2G BLOCKSIZE 512)
UNDO TABLESPACE DATAFILE '?/dbfiles/undo' size 2G autoextend ON NEXT 256M MAXSIZE 64G
SWAP TABLESPACE TEMPFILE '?/dbfiles/swap' size 2G autoextend ON NEXT 256M MAXSIZE 64G
SYSTEM TABLESPACE DATAFILE 'system' size 128M MEMORY MAPPED
DEFAULT TABLESPACE DATAFILE '?/dbfiles/users' size 5G;
# create_multiple_instance_database
该语句用于在共享集群部署下创建多实例数据库。
# database_name
指定要创建的数据库的名称,不可省略,且需符合YashanDB的对象命名规范。
# instances interger
该语句用于指定共享集群部署下多实例数据库的实例个数,最大值为4,可省略。若省略,则必须指定instance_clause。
# attribute_clause
指定除redo文件和undo文件之外的数据库配置,这些属性定义与创建单实例数据库时的属性定义一致,见create_single_instance_database中的attribute_clause。
Note:
共享集群部署中redo、undo、swap、default等所有数据文件路径需指定为YFS路径,否则返回错误。
# instance_clause
该语句用于指定共享集群部署下多实例数据库每个实例相关undo、redo日志文件和数据文件配置,根据所需实例个数多次指定本语句,最多支持指定4次(即创建4个实例),语句之间使用空格间隔。
示例(共享集群部署)
--通过INSTANCES关键字创建2个实例的数据库,数据库文件均为默认属性
CREATE cluster DATABASE yashan instances 2;
--通过instance_clause语句创建2个实例的数据库,且自定义数据库文件属性
CREATE cluster DATABASE yashan
SYSTEM TABLESPACE DATAFILE 'system' size 64M
SYSAUX TABLESPACE DATAFILE 'sysaux' size 64M
DEFAULT TABLESPACE DATAFILE 'users' size 64M
TEMPORARY TABLESPACE TEMPFILE 'temp' size 64M
SWAP TABLESPACE TEMPFILE 'swap' size 64M
instance(
LOGFILE('logfile11' size 32M, 'logfile12' size 32M, 'logfile13' size 32M)
UNDO TABLESPACE DATAFILE 'undo1' size 64M
)
instance (
LOGFILE('logfile21' size 32M, 'logfile22' size 32M, 'logfile23' size 32M)
UNDO TABLESPACE DATAFILE 'undo2' size 64M
);
--指定路径的配置
CREATE cluster DATABASE yashan
instance (
LOGFILE('+DG_0/redo1' size 128M BLOCKSIZE 512,
'+DG_0/redo2' size 128M BLOCKSIZE 512)
UNDO TABLESPACE DATAFILE '+DG_0/undo1' size 128M autoextend ON)
SWAP TABLESPACE TEMPFILE '+DG_0/swap' size 128M autoextend ON
SYSAUX TABLESPACE DATAFILE '+DG_0/sysaux' size 128M autoextend ON
SYSTEM TABLESPACE DATAFILE '+DG_0/system' size 128M autoextend ON
TEMPORARY TABLESPACE TEMPFILE '+DG_0/temp' size 128M autoextend ON
DEFAULT TABLESPACE DATAFILE '+DG_0/users' size 128M autoextend ON;