结构化变量与常规系统变量有两个不同之处:
它的值是一个包含指定被认为密切相关的服务器参数的组件的结构。
给定类型的结构化变量可能有多个实例。每一个都有不同的名称,引用服务器维护的不同资源。
MySQL支持一种结构化变量类型,它指定控制键缓存操作的参数。一个关键的缓存结构变量有以下组件:
本节描述引用结构化变量的语法。在语法示例中使用了键缓存变量,但是关于键缓存如何操作的具体细节可以在其他地方找到第8.10.2节“MyISAM密钥缓存”.
中引用结构化变量实例的组件,可以使用复合名称instance_name.component_name
格式。例子:
hot_cache。key_buffer_size hot_cache。key_cache_block_sizecold_cache.key_cache_block_size
对于每个结构化系统变量,一个名为的实例默认的
总是预定义的。如果引用结构化变量的组件而没有任何实例名,则默认的
使用实例。因此,default.key_buffer_size
而且key_buffer_size
两者都指向同一个系统变量。
结构化变量实例和组件遵循以下命名规则:
对于给定类型的结构化变量,每个实例必须有一个惟一的名称在这种类型的变量。然而,实例名不必是唯一的在结构化的变量类型。例如,每个结构化变量都有一个名为
默认的
,所以默认的
在变量类型中不是唯一的。每个结构化变量类型的组件名称在所有系统变量名称中必须是唯一的。如果这不是真的(也就是说,如果两种不同类型的结构化变量可以共享组件成员名),那么对于不受实例名限制的成员名的引用,将不清楚使用哪个默认结构化变量。
如果结构化变量实例名作为不加引号的标识符不合法,则使用反引号将其作为加引号的标识符引用。例如,
热缓存
是不合法的,但是“热缓存”
是多少。全球
,会话
,当地的
不是合法的实例名。这避免了与诸如@@GLOBAL。
用于引用非结构化系统变量。var_name
目前,不可能违反前两条规则,因为唯一的结构化变量类型是用于键缓存的变量类型。如果将来创建了其他类型的结构化变量,那么这些规则可能具有更大的意义。
除了一个例外,您可以在任何可能出现简单变量名的上下文中使用复合名称引用结构化变量组件。例如,你可以使用命令行选项给一个结构化变量赋值:
$ > mysqld——hot_cache.key_buffer_size = 64 k
在选项文件中,使用以下语法:
(mysqld) hot_cache.key_buffer_size = 64 k
如果使用此选项启动服务器,它将创建一个名为hot_cache
除了默认大小为8MB的默认键缓存外,该缓存的大小为64KB。
假设您按以下方式启动服务器:
$> mysqld——key_buffer_size=256K \——extra_cache。key_buffer_size=128K \ --extra_cache.key_cache_block_size=2048
在本例中,服务器将默认密钥缓存的大小设置为256KB。(你也可以写——default.key_buffer_size = 256 k
)。此外,服务器创建第二个密钥缓存extra_cache
它的大小为128KB,用于缓存表索引块的块缓冲区的大小设置为2048字节。
下面的示例启动服务器,使用三个不同的键缓存,大小比例为3:1:1:
$> mysqld——key_buffer_size=6M \——hot_cache。key_buffer_size=2M \ --cold_cache.key_buffer_size=2M
结构化变量值也可以在运行时设置和检索。例如,要设置一个名为hot_cache
修改为10MB,使用以下语句之一:
设置全局热缓存。key_buffer_size= 10*1024*1024; mysql> SET @@GLOBAL.hot_cache.key_buffer_size = 10*1024*1024;
要检索缓存大小,请执行以下操作:
mysql >选择@@GLOBAL.hot_cache.key_buffer_size;
但是,下面的语句不起作用。变量没有被解释为复合名称,而是被解释为a的简单字符串就像
模式匹配操作:
mysql>显示全局变量如“hot_cache.key_buffer_size”;
这是在任何可能出现简单变量名的地方都能够使用结构化变量名的例外。