SAP HANA 管理 - 表管理



SAP HANA 支持可以在传统数据库中执行的所有数据库功能。您可以创建数据库表、视图、触发器、同义词、存储过程和其他数据库函数。在 SAP HANA 中,您可以创建两种类型的表:

  • 行存储
  • 列存储

SAP HANA 列存储表适用于执行性能优化的读取操作以及执行写入操作。您可以实现高达 11 倍的数据压缩,并且与列存储表相比,搜索和计算可以更快地执行。SAP HANA 的数据分区功能仅适用于列存储表,并且 SAP HANA 数据建模只能用于列存储表。

行存储表更适合对小型表执行 INSERT 和 UPDATE SQL 语句。

在 SAP HANA 数据库中,可以连接不同的存储表类型 - 行存储表可以连接到列存储表,但建议将类似的表类型连接在一起以保持高性能。

使用 HANA Studio 中的 GUI 选项在 HANA 数据库中创建表

右键单击架构下的“表”选项卡→选择“新建表”选项,如下面的屏幕截图所示。

单击“新建表”后,将打开一个窗口以输入表名。从下拉列表中选择架构名称→从下拉列表中定义表类型:列存储或行存储。

定义数据类型,如下面的屏幕截图所示,可以通过单击“+”号添加列。可以通过单击列名前“主键”下的单元格来选择主键。默认情况下,“非空”将处于活动状态。添加列后,单击“执行”。

在下面的屏幕截图中,您可以看到表类型为列存储。您可以通过从下拉列表中选择“行存储”来创建行存储表。

在使用 SQL 语句创建表时,需要在 Create Table 命令中提及“Column”关键字。默认情况下,它使用 SQL 编辑器创建行存储表。

Column

执行 (F8) 后,右键单击“表”选项卡→“刷新”。新表将反映在所选架构下的表列表中。

注意 - 您还可以使用 SQL 编辑器中的以下 Alter 命令更改 SAP HANA 数据库中的表类型。

Alter table_name Column; 

使用列存储表的优势

以下是与行存储相比,使用列存储表的优势:

性能优化的列操作

与行存储表相比,您可以更快地执行复杂的计算和聚合。这消除了在 HANA 数据库中存储聚合表的需要,因此也节省了内存空间。

列表的内置索引

对表使用列式数据结构消除了索引的需要,因为当您将数据存储在列中时,它就像每列的内置索引一样。这节省了内存空间,并在写入操作期间提高了性能。

数据压缩

当您将基于列的表存储在 HANA 数据库中时,类似的数据类型会在内存中连续存储。它允许您应用各种数据压缩技术,例如 - 运行长度压缩、字典压缩,从而减少存储表所需的存储空间。与传统数据库相比,您可以实现高达 11 倍的数据压缩。

并行处理

通过使用多核处理器,您可以在列存储表上执行并行处理。由于数据是垂直存储的,因此可以在基于列的表上轻松处理列操作。

广告