WEB开发网
开发学院数据库MySQL MySQL查询优化-Admin 阅读

MySQL查询优化-Admin

 2007-02-13 10:53:59 来源:WEB开发网   
核心提示: · 查询缓存是基于服务器所接收到的查询字符串的文本内容的,如果某些查询的文本完全相同,MySQL查询优化-Admin(5),那些它就认为这些查询是相同的,如果某些查询的字符不同,· query_cache_size决定分配给缓存的内存数量,单位是字节,或者来自那

· 查询缓存是基于服务器所接收到的查询字符串的文本内容的。如果某些查询的文本完全相同,那些它就认为这些查询是相同的。如果某些查询的字符不同,或者来自那些使用了不同的字符集或通讯协议的客户端,那么它会认为这些查询是不同的。同样,如果某些查询采用其它的功能相当、但是实际上没有指向相同的数据表(例如引用了不同的数据库中的同名数据表),那么它们也是不同的。

· 当数据表被更新了之后,涉及到该数据表的任何缓存查询都变成无效的,并且会被丢弃。这可以防止服务器返回过期的结果。

在默认情况下,MySQL对查询缓存的支持是内建的。如果你不希望使用这种缓存,并且想避免它所导致的性能开销,可以使用--without-query-cache选项来运行配置脚本建立服务器。

如果需要检测某个服务器是否支持查询缓存,可以检查它的have_query_cache系统变量:

mysql> SHOW VARIABLES LIKE ’have_query_cache’;
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| have_query_cache | YES |
+------------------+-------+

对于那些支持查询缓存的服务器来说,缓存的操作是基于三个系统变量值的:

· query_cache_type决定查询缓存的操作模式。下表显示了可以使用的模式值:

模式 含义

0 不要缓存查询结果或检索缓存的结果。

1 缓存查询,除非它们以SELECT SQL_NO_CACHE开头。

2 根据需要只缓存那些以SELECT SQL_CACHE开头的查询。

· query_cache_size决定分配给缓存的内存数量,单位是字节。

· query_cache_limit设置被缓存的最大结果集大小;比这个值大的查询结果不会被缓存。

上一页  1 2 3 4 5 6 7  下一页

Tags:MySQL 查询 优化

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接