DM有两种由系统建立和管理的数据库:一种是系统数据库(SYSTEM.DBF),用于存放数据词典中的系统表信息以及用户在它上面建立的各类数据库对象;另外一种是系统运行时建立的临时数据库(TMPDBxxx.DBF),临时数据库有多个,具体个数在DM.INI文件中进行设置,也就是对DM.INI文件中的TEMP_DBS项进行赋值。sql
除上面两种由系统建立和管理的数据库以外,用户能够自行创建一个或多个用户数据库。各个数据库间具备必定的相互独立性,库中全部对象的做用范围都不能超出其所在的库。数据库
数据库定义语句格式:spa
CREATE DATABASE <数据库名><文件生成子句>[<是否归档子句>] [<归档目录子句>][<备份目录子句>]
语句功能:供DBA或具备CREATE_DATABASE权限的用户建立一个新数据库及存储该数据库的文件。操作系统
使用说明:日志
1.所指定的数据库和文件不能是已经存在的。code
2.文件大小不小于(4*页大小)MB,文件大小的上限由操做系统限定。对象
3.库文件的页大小、簇大小等在安装时统一指定,之后不能更改。class
4.一个已经存在的数据必须通过分离以后才能添加,分离数据库参考数据库删除语法。登录
5.附加数据库时,文件指定语句中文件的编号能够经过存储过程SP_ATTACH_GET_FILE_LIST(CTL_PATH VARCHAR(256))得到,附加数据库的基本信息(如:页大小,簇大小等)能够经过存储过程 SP_GET_ ATTACH_INFO(CTL_PATH VARCHAR(256))得到。扩展
举例说明 例 建立数据库 BOOKSHOP,数据文件存放路径为 C:\DMDBMS\data (该路径必须存在,不然创 建数据库语句不能执行成功),数据库文件名为 BOOKSHOP.DBF,大小为 50MB(假设每页大小为 8K)。 CREATE DATABASE BOOKSHOP DATAFILE 'C:\DMDBMS\data\BOOKSHOP.DBF' SIZE 50 例 附加数据库 BOOKSHOP,数据库控制文件为 C:\DMDBMS\data\BOOKSHOP01.CTL 和 C:\DMDBMS\data\BOOKSHOP02.CTL ,数据库的其余数据文件默认为控制文件中文件路径。 CREATE DATABASE BOOKSHOP ATTACH FROM 'C:\DMDBMS\data\BOOKSHOP01.CTL',' C:\DMDBMS\data\BOOKSHOP02.CTL ';
一个数据库建立成功后,能够经过增大原有数据库文件大小,或在该数据库中加入新的数据库文件两种方式来修改(增大)该数据库空间。
修改数据库语句格式:
ALTER DATABASE <数据库名><修改数据库语句>
语句功能功能:供具备DBA权限的用户修改(增长)数据库空间或增长文件组以及增长文件组中数据文件。
使用说明:
1.对于<ADD子句>,所指定的数据文件在指定文件路径下并不存在,在此命令执行成功后才会生成;对于<MODIFY子句>,必须对已存在的数据文件进行操做;
2.对于所指定的整数值,其单位是MB;
3.对日志文件进行扩展时,若是是当前正在使用的日志文件,扩展会失败。
举例说明 假设数据库 BOOKSHOP 页面大小为 8K,数据文件存放路径为 C:\DMDBMS\data。 例 给 BOOKSHOP 数据库增长一个新数据文件 BOOKSHOP1.DBF,其大小为 40M: ALTER DATABASE BOOKSHOP ADD DATAFILE 'C:\DMDBMS\data\BOOKSHOP1.DBF' SIZE 40; 例 扩展 BOOKSHOP 数据库中的这个数据文件,使其大小增大为 50M: ALTER DATABASE BOOKSHOP MODIFY DATAFILE 'C:\DMDBMS\data\BOOKSHOP1.DBF ' INCREASE 10; 例 增长文件组 FG_PERSON 在默认位置: ALTER DATABASE BOOKSHOP ADD FILEGROUP FG_PERSON 'C:\DMDBMS\data\FG_PERSON.DBF' SIZE 50; 例 增长文件组 FG_PRODUCTION 在其它位置: ALTER DATABASE BOOKSHOP ADD FILEGROUP FG_PRODUCTION 'C:\EXP\FG_PRODUCTION.DBF' SIZE 50; 例 在文件组 FG_PERSON 中增长数据文件在默认位置: ALTER DATABASE BOOKSHOP ADD DATAFILE 'C:\DMDBMS\data\FG_PERSON1.DBF' SIZE 50 ON FILEGROUP FG_PERSON; 例 在文件组 FG_PRODUCTION 中增长数据文件在其它位置: ALTER DATABASE BOOKSHOP ADD DATAFILE 'C:\EXP\FG_PRODUCTION1.DBF' SIZE 50 ON FILEGROUP FG_PRODUCTION; 例 设置数据库 BOOKSHOP 联机: ALTER DATABASE BOOKSHOP SET ONLINE; 例 设置数据库 BOOKSHOP 脱机: ALTER DATABASE BOOKSHOP SET OFFLINE;
删除数据库
语句格式:
DROP DATABASE <数据库名> [CASCADE][DETACH];
语句功能:
供DBA权限的用户删除数据库。
使用说明:
1.使用者应拥有DBA权限;
2.没法删除系统数据库(SYSTEM.DBF、临时数据库);
3.使用CASCADE选项,删除该数据库及其所包含的全部文件的同时,也将删除其全部备份文件;不然,删除该数据库及其包含的全部文件,但保留备份文件;
4.使用DETACH选项,分离数据库,不删除数据库文件(控制文件、数据文件、回滚文件、日志文件)。
举例说明 例 删除数据库 BOOKSHOP: DROP DATABASE BOOKSHOP; 例 删除数据库 BOOKSHOP 及其备份文件: DROP DATABASE BOOKSHOP CASCADE; 例 分离数据库 BOOKSHOP: DROP DATABASE BOOKSHOP DETACH;
设置当前活动数据库
语句格式:
SET [CURRENT DATABASE] | [[CURRENT] CATALOG] <数据库名>;
语句功能:
供用户指定当前活动数据库。
使用说明:
若是用户登陆系统时指定了要登陆到哪一个数据库,登陆成功后,该数据库就是当前数据库;若是登陆时没有指定登陆哪一个数据库,则登陆的将是用户所使用的登陆对应的缺省数据库,登陆成功后,该缺省数据库就是当前数据库。
该语句供用户指定当前活动数据库,接下来的未指定数据库名的操做都在设定的当前数据库上进行,直至指定另外一数据库为当前数据库为止。
举例说明 例 设当前活动数据库为 SYSTEM,用户要在另外一个数据库 BOOKSHOP 上进行一系列数据操 做,则可利用如下语句将当前活动数据库设置为 BOOKSHOP。 SET CURRENT DATABASE BOOKSHOP;