达梦支持的表类型包括:
- 普通表
- 临时表
- 水平分区表
- 堆表
- 列存储表
每个表都含有一个聚集索引,默认以 ROWID
建立,建立合适的聚集索引,可以有效加快表的检索效率。
普通表
表是数据库中数据存储的基本单元,是对用户数据进行读和写操纵的逻辑实体。表由列和行组成,每一行代表一个单独的记录。
列的特性由两部分组成:数据类型和长度。
为了确保数据库中数据的一致性和完整性,在创建表时可以定义表的实体完整性、域完整性和参考完整性。
实体完整性:定义表中的所有行能唯一地标识;
域完整性:通常指数据的有效性;
参考完整性:维护表间数据的有效性、完整性;
创建表时,在 storage
子句中,可对表指定存储的表空间。如果没有指定,则该表将创建在用户的默认表空间中。
在创建表时,通过指定合适的表空间,有以下优点:
- 提高数据库性能的性能,因为不同的数据库表可能对应不同的数据文件,可减少对相同文件的竞争;
- 减少数据库管理的时间,数据库表分布在不同的表空间中,即使一个表空间损坏,也不影响其他表空间上数据库表的正常访问。
创建表
使用 create table
的语句来创建表。
create table user (
id int primary key,
sex int
)
storage (
on users
);
更改表
使用 alter table
来更改。
alter table user ( sex varchar(1) );
用户可以实现的操作有:
- 添加或删除列,或修改现有列的定义;
- 添加、修改或删除与表相关的完整性约束;
- 重命名一个表;
- 启动或停用与表相关的完整性约束;
- 启动或停用与表相关的触发器;
- 修改表的 SPACE LIMIT;
- 增删自增列;
删除表
使用 drop table
来删除表。
drop table user;
删除表时,将产生以下结果:
- 表的结构信息从数据字典中删除,表中的数据不可访问;
- 表上的所有索引和触发器被一起清除;
- 所有建立在该表上的同义词、视图和存储过程变为无效;
- 所有分配给标的簇标记为空闲,可被分配给其他的数据库对象;
清空表
DM8 支持三种方式来删除表中的所有列:
- 使用 DELETE 语句:
delete from user
- 使用 DROP 和 CREATE 语句:
drop table user; create table user (…)
- 使用 TRUNCATE 语句:
truncate table user
delete
语句操作需要 CPU 时间,并且会产生大量的 redo 日志和 undo 记录。如果表上关联了元组级触发器,每删除一行,就会启动一次触发器。这两种操作都会消耗大量的资源。
truncate
是一个 DDL 语句,不会产生任何回滚信息。执行 truncate
会立即提交,而且不能回滚。
truncate
语句并不影响被删除的表相关联的任何结构、约束、触发器或授权。
查看表信息
可以通过 sp_tabledef
系统过程来查看表的定义。
call sp_tabledef('SYSDBA', 'user');
<