ABAP SCREEN的内表列数有限制吗

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ABAP SCREEN的内表列数有限制吗相关的知识,希望对你有一定的参考价值。

参考技术A 你是说ABAP定义内表,字段有没有限制吧;
基本没有限制,不过你定义的时候尽量简单(不要定义不必要的字段),因为后续如果需要对内表进行处理的时候,字段过多会很影响效率;同时,SELECT查询数据库数据赋值内表时,也尽量查询内表有的字段 不要用*

MySQL 表列数和行大小有哪些限制?

列数限制

MySQL对每个表有4096列的硬限制,但是对于给定的表,有效最大值可能会更少。确切的列限制取决于几个因素:

  • 表的最大行大小限制了列的数量(可能还有大小),因为所有列的总长度不能超过该大小

  • 个列的存储要求限制了给定最大行大小内的列数。某些数据类型的存储要求取决于存储引擎,存储格式和字符集等因素

  • 存储引擎可能会施加其他限制表列计数的限制。例如, InnoDB每个表的限制为1017列

  • 功能键部分被实现为隐藏的虚拟生成的存储列,因此表索引中的每个功能键部分都计入表的总列数限制。

MySQL 表列数和行大小有哪些限制?

行大小限制

给定表的最大行大小由几个因素决定:

  • MySQL表的内部表示具有65,535字节的最大行大小限制,即使存储引擎能够支持更大的行也是如此。BLOBTEXT列仅有助于朝向行大小限制9〜12字节,因为它们的内容是从该行的其余部分分开存储。

  • InnoDB 对于4KB,8KB,16KB和32KBinnodb_page_size 设置,表 的最大行大小(适用于本地存储在数据库页面内的数据)略小于页面的一半 。例如,对于默认的16KBInnoDB页面大小,最大行大小略小于8KB 。对于64KB页面,最大行大小略小于16KB

  • 如果包含 可变长度列的InnoDB 行超出最大行大小,请InnoDB选择可变长度列进行外部页外存储,直到该行适合InnoDB 行大小限制。对于行外存储的变长列,本地存储的数据量因行格式而异。

  • 不同的存储格式使用不同数量的页面标题和尾部数据,这会影响行可用的存储量(这里不做展开,感兴趣的可以查阅官网了解详情)


行大小限制案例
MySQL 表列数和行大小有哪些限制?
MySQL 表列数和行大小有哪些限制?

在下面的MyISAM例子中,改变柱TEXT 避免了65535字节的行大小限制,并且允许成功,因为操作 BLOB和 TEXT列仅有助于朝向行大小9至12个字节。

MySQL 表列数和行大小有哪些限制?

操作成功执行InnoDB 表,因为更改列以 TEXT避免MySQL 65,535字节行大小限制,并且InnoDB 可变长度列的页外存储避免了 InnoDB行大小限制。

MySQL 表列数和行大小有哪些限制?

可变长度列的存储包括长度字节,它们被计入行大小。例如, VARCHAR(255) CHARACTER SET utf8mb3列需要两个字节来存储值的长度,因此每个值最多可以占用767个字节。


t1 由于列需要32,765 + 2个字节和32,766 + 2个字节,因此 创建表的语句成功,最大行大小为65,535字节:

MySQL 表列数和行大小有哪些限制?

将列长度减少到65,533或更少可允许语句成功。

MySQL 表列数和行大小有哪些限制?

对于MyISAM表, NULL列需要行中的额外空间才能记录其值 NULL。每NULL 列需要一位额外的值,向上舍入到最接近的字节。


创建表的语句t3失败,因为除了可变长度列长度字节所需的空间之外,还MyISAM需要NULL列的空间,导致行大小超过65,535字节:

MySQL 表列数和行大小有哪些限制?

InnoDB将行大小(对于数据库页面中本地存储的数据)限制为略小于4KB,8KB,16KB和32KB innodb_page_size 设置的数据库页面的一半,对于64KB页面,将行大小限制 为略小于16KB。

t4由于定义的列超过16KB InnoDB页面的行大小限制,因此 创建表的语句失败。

- END -


往期推荐



以上是关于ABAP SCREEN的内表列数有限制吗的主要内容,如果未能解决你的问题,请参考以下文章

详解ABAP/4内表结构

SAP ABAP中的内表

ABAP 中内表的复制

ABAP中clearrefreshfree三者清空内表的区别

MySQL 表列数和行大小有哪些限制?

MySQL表列数和行大小限制