下面对MySQL查询缓存变量作了详尽的阐述,并对MySQL查询缓存变量过程中的步骤进行了分析,如果您对此方面感兴趣的话,不妨一看。
MySQL查询缓存变量解释:Qcache_free_blocks:缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE会对缓存中的碎片进行整理,从而得到一个空闲块。Qcache_free_memory:缓存中的空闲内存。Qcache_hits:每次查询在缓存中命中时就增大Qcache_INSERTs:每次插入一个查询时就增大。命中次数除以插入次数就是不中比率。Qcache_lowmem_prunes:缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间来看;如果这个数字在不断增长,就表示可能碎片非常严重,或者内存很少。(上面的 free_blocks和free_memory可以告诉您属于哪种情况)Qcache_not_cached:不适合进行MySQL查询缓存变量,通常是由于这些查询不是 SELECT 语句或者用了now()之类的函数。Qcache_queries_in_cache:当前缓存的查询(和响应)的数量。Qcache_total_blocks:缓存中块的数量。我们再查询一下 服务器 关于query_cache的配置:
各字段的解释:query_cache_limit:超过此大小的查询将不缓存query_cache_min_res_unit:缓存块的最小大小query_cache_size:查询缓存大小query_cache_type:缓存类型,决定缓存什么样的查询,示例中表示不缓存 select sql_no_cache 查询query_cache_wlock_invaliDate:当有其他客户端正在对MyISAM表进行写操作时,如果查询在query cache中,是否返回cache结果还是等写操作完成再读表获取结果。query_cache_min_res_unit的配置是一柄”双刃剑”,默认是4KB,设置值大对大数据查询有好处,但如果你的查询都是小数据查询,就容易造成内存碎片和浪费。查询缓存碎片率 = Qcache_free_blocks / Qcache_total_blocks * 100%如果查询缓存碎片率超过20%,可以用FLUSH QUERY CACHE整理缓存碎片,或者试试减小query_cache_min_res_unit,如果你的查询都是小数据量的话。查询缓存利用率 = (query_cache_size – Qcache_free_memory) / query_cache_size * 100%查询缓存利用率在25%以下的话说明query_cache_size设置的过大,可适当减小;查询缓存利用率在80%以上而且Qcache_lowmem_prunes > 50的话说明query_cache_size可能有点小,要不就是碎片太多。查询缓存命中率 = (Qcache_hits – Qcache_inserts) / Qcache_hits * 100%示例服务器 查询缓存碎片率 = 20.46%,查询缓存利用率 = 62.26%,查询缓存命中率 = 1.94%,命中率很差,可能写操作比较频繁吧,而且可能有些碎片。
【编辑推荐】
MySQL慢查询的启用方法
Mysql多表查询的实现
MySQL CONVERT函数简介
Liunx下修改MySQL字符集的方法
带您了解mysql变量

求:从查询结果里,再查询最小值的SQL语句
答案如下:SELECT TOP 1 year,month From[你的表名] Order BYver,year,month分析的思路:从题目上看,要求查询的ver year month都要求是查询最小值,那么我们能想到查询最小值的方法有很多,其中最简便的一种思路就是从小到大排序,然后我们取出第一个,不就是我们需要的最小值了么,有这个思路,就直接对ver year month都排序(DESC是降序排列,ASC是升序,一般我们在ORDER BY 后不写的时候,默认就是ASC),取第一行的值,那么就是TOP 1,由此得出我们的答案。 遇到问题以后,学会“切片”来分析,它需要干什么,你就找对应的方法,然后把这些方案串起来,就可以解决问题啦。 拿本题来说:(1):找到最小值的方法:从小到大排序,最小值就出来了。 (2):怎么拿到最小值,TOP 1 拿到第一行也就等同于拿到最小值。 希望可以帮助到你,^_~
wanp 里怎么使用mysql 命令行
1启动控制台 单击wamp5图标->mysql->mysql控制台2输入密码(wamp5默认密码为空)按回车3mysql信息:4显示所有数据库5选择数据库 use dbname6显示表(show tables;)命令大全* mysql 链接服务器 mysql -h localhost-u root -p * show databsses 显示数据库* use dbname选择数据库 * show tables 显示数据表 *create database 数据库名 建库* drop database dbname 删除库* delete database dbname 删除库* create table ( [,.. ]) 建表 * rename table 原表名 to 新表名 改表名 * update 表名 set 字段=新值,… where 条件 修改表中数据 * update 表名 set 字段名 = 新内容 更改表字段 * show character set 显示字符集 * show collation 显示字符集的校对 * character set 字符集名 计置字符集 * set names 计置字符集 * character_set_client 客户端字符集 * character_set_connection 链接字符集 * character_set_results 返回字符集 * insert into select fieldname from ; 从其他表导入数据
mysql存储过程中 declare 和 set 定义变量的区别
mysql存储过程中 declare 和 set 定义变量的区别declare为对变量进行声明,声明必须制定变量的数据类型,只能写在过程的前面set是对变量赋值,可以放在过程的任何地方对没有declare声明过的变量赋值,该变量必须以加上@号,否则会报错DECLARE a INT;-- 如果放在下面语句之后,会报错SET a = (SELECT id FROM tb);-- 如果没有前面的声明,会报错SET @b = (SELECT title FROM tb);
发表评论