一个关系数据库管理系统的实例中可以建立多个数据库,一个数据库可以建立多个模式,一个模式通常包括多个表、视图、索引等数据库对象。

创建了一个模式就建立了一个数据库的命名空间,一个框架。

定义模式语句:
CREATE SCHEMA <模式名> <用户名>;

如果没有指定<模式名> 那么 <模式名> 隐含为 <用户名>。
例如:

CREATE SCHEMA WANG;

该语句没有指定<模式名>,所以<模式名>隐含为用户名WANG。

目前,在CREATE SCHEMA 中可以接受CREATE TABLE , CREATE VIEW和GRANT子句。也就是说用户可以在创建模式的同时在这个模式定义中进一步创建基本表、视图,定义授权。即

CREATE SCHEMA <模式名> AUTHORIZATION <用户名> [<表定义子句>|<视图定义子句>|<授权定义子句>];

例如:为用户ZHANG创建一个模式TEST,并且在其中定义一个表TAB1。

CREATE SCHEMA TEST ZHANG
CREATE TABLE TAB1 (COL1 SMALLINT,
					COL2 INT,
					COL3 CHAR(20),
					COL4 NUMERIC(10,3),
					COL5 DECIMAL(5,2)
					);
删除语句:
DROP SCHEMA <模式名><CASCADE|RESTRICT>;

其中CASCADE和RESTRICT 两者必选其一。选择了CASCADE(级联),表示在删除模式的同时把该模式中所有的数据库对象全部删除,选择了RESTRICT(限制),表示如果该模式中已经定义了下属的数据库对象(如表、视图等),则拒绝该删除语句的执行。只有但该模式中没有下属的对象时才能执行DROP SCHEMA语句。

例如:

DROP SCHEMA ZHANG CASCADE;

该语句删除了模式ZHANG,同时,该模式中已经定义的表TAB1也被删除了。

更多推荐

SQL模式的定义