结构化变量与常规系统变量在两个方面不同:
它的值是一个结构,其中的组件指定了被认为密切相关的服务器参数。
给定类型的结构变量可能有多个实例。每个名称都有不同的名称,并且指的是服务器维护的不同资源。
MySQL支持一种结构化变量类型,该结构化类型指定用于控制键缓存操作的参数。键高速缓存结构化变量具有以下组件:
key_buffer_size
key_cache_block_size
key_cache_division_limit
key_cache_age_threshold
本节描述了引用结构变量的语法。将密钥缓存变量用于语法示例,但是有关密钥缓存如何工作的特定详细信息,请参见第8.10.2节“ MyISAM密钥缓存”。
要引用结构变量实例的组件,可以使用instance_name.component_name格式的复合名称 。例子:
hot_cache.key_buffer_size
hot_cache.key_cache_block_size
cold_cache.key_cache_block_size
对于每个结构化系统变量,default总是预定义名称为的实例。如果引用的结构变量的组件没有任何实例名称,default则使用该实例。因此, default.key_buffer_size与 key_buffer_size这两个指代相同的系统变量。
结构化变量实例和组件遵循以下命名规则:
1、对于给定类型的结构化变量,每个实例必须具有在 该类型的变量内唯一的名称。但是,实例名称不必在结构化变量类型之间唯一。例如,每个结构化变量都有一个名为的实例default,因此 default在变量类型之间不是唯一的。
2、每个结构变量类型的组件名称在所有系统变量名称中必须唯一。如果不正确(也就是说,如果两种不同类型的结构化变量可以共享组件成员名称),则不清楚要使用哪个默认结构化变量来引用不受实例名称限定的成员名称。
3、如果结构变量实例名称作为未引用标识符不合法,请使用反引号将其引用为引用标识符。例如,hot-cache 不合法,但是合法hot-cache。
4、global,session和 local不是合法实例名称。这避免了与诸如 引用非结构化系统变量之类的符号的冲突 。 @@GLOBAL.var_name
当前,前两个规则不可能被违反,因为唯一的结构化变量类型是键缓存的类型。如果将来会创建其他类型的结构化变量,这些规则将具有更大的意义。
除了一个例外,您可以在可能出现简单变量名称的任何上下文中使用复合名称来引用结构化变量组件。例如,您可以使用命令行选项将值分配给结构化变量:
shell>mysqld --hot_cache.key_buffer_size=64K
在选项文件中,使用以下语法:
[mysqld]
hot_cache.key_buffer_size=64K
如果使用此选项启动服务器,则hot_cache除了默认大小为8MB的默认密钥缓存外,它还会创建一个大小为64KB的密钥缓存。
假设您按以下方式启动服务器:
shell>mysqld --key_buffer_size=256K \
--extra_cache.key_buffer_size=128K \
--extra_cache.key_cache_block_size=2048
在这种情况下,服务器会将默认密钥缓存的大小设置为256KB。(您也可能已经写过 --default.key_buffer_size=256K。)此外,服务器还会创建一个名为extra_cache128KB 的第二个键高速缓存,并将 用于缓存表索引块的块缓冲区的大小设置为2048字节。
以下示例使用大小为3:1:1的三个不同的键高速缓存启动服务器:
shell>mysqld --key_buffer_size=6M \
--hot_cache.key_buffer_size=2M \
--cold_cache.key_buffer_size=2M
结构化变量值也可以在运行时设置和检索。例如,要设置名为hot_cache10MB 的密钥缓存 ,请使用以下任一语句:
mysql>SET GLOBAL hot_cache.key_buffer_size = 10*1024*1024;
mysql>SET @@GLOBAL.hot_cache.key_buffer_size = 10*1024*1024;
要检索缓存大小,请执行以下操作:
mysql> SELECT @@GLOBAL.hot_cache.key_buffer_size;
但是,以下语句不起作用。该变量不解释为复合名称,而是解释为LIKE模式匹配操作的简单字符串 :
mysql> SHOW GLOBAL VARIABLES LIKE 'hot_cache.key_buffer_size';
这是例外,它可以在可能出现简单变量名的任何地方使用结构化变量名。