Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wushizhenking
JavaGuide
提交
95d5aee9
J
JavaGuide
项目概览
wushizhenking
/
JavaGuide
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
JavaGuide
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
95d5aee9
编写于
8月 07, 2021
作者:
2022年度最佳搬砖户
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修改MySQL查询缓存内容
上级
a1342f76
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
2 addition
and
2 deletion
+2
-2
docs/database/MySQL.md
docs/database/MySQL.md
+2
-2
未找到文件。
docs/database/MySQL.md
浏览文件 @
95d5aee9
...
...
@@ -174,9 +174,9 @@ set global query_cache_type=1;
set
global
query_cache_size
=
600000;
```
如上,
**开启查询缓存后在同样的查询条件以及数据情况下,会直接在缓存中返回结果**
。这里的查询条件包括查询本身、当前要查询的数据库、客户端协议版本号等一些可能影响结果的信息。
因此任何两个查询在任何字符上的不同都会导致缓存不命中。此外,
如果查询中包含任何用户自定义函数、存储函数、用户变量、临时表、MySQL 库中的系统表,其查询结果也不会被缓存。
如上,
**开启查询缓存后在同样的查询条件以及数据情况下,会直接在缓存中返回结果**
。这里的查询条件包括查询本身、当前要查询的数据库、客户端协议版本号等一些可能影响结果的信息。
(
**查询缓存不命中的情况:(1)**
)因此任何两个查询在任何字符上的不同都会导致缓存不命中。此外,(
**查询缓存不命中的情况:(2)**
)
如果查询中包含任何用户自定义函数、存储函数、用户变量、临时表、MySQL 库中的系统表,其查询结果也不会被缓存。
缓存建立之后
,MySQL 的查询缓存系统会跟踪查询中涉及的每张表,如果这些表(数据或结构)发生变化,那么和这张表相关的所有缓存数据都将失效。
(
**查询缓存不命中的情况:(3)**
)
**缓存建立之后**
,MySQL 的查询缓存系统会跟踪查询中涉及的每张表,如果这些表(数据或结构)发生变化,那么和这张表相关的所有缓存数据都将失效。
**缓存虽然能够提升数据库的查询性能,但是缓存同时也带来了额外的开销,每次查询后都要做一次缓存操作,失效后还要销毁。**
因此,开启查询缓存要谨慎,尤其对于写密集的应用来说更是如此。如果开启,要注意合理控制缓存空间大小,一般来说其大小设置为几十 MB 比较合适。此外,
**还可以通过 sql_cache 和 sql_no_cache 来控制某个查询语句是否需要缓存:**
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录