File tree Expand file tree Collapse file tree 1 file changed +6
-3
lines changed Expand file tree Collapse file tree 1 file changed +6
-3
lines changed Original file line number Diff line number Diff line change @@ -144,11 +144,14 @@ MySQL执行以下命令也可以开启查询缓存
144
144
set global query_cache_type =1;
145
145
set global query_cache_size =600000;
146
146
```
147
- 如上,** 开启查询缓存后在同样的查询条件以及数据情况下,会直接在缓存中返回结果** 。这里的查询条件包括查询本身、当前要查询的数据库、客户端协议版本号等一些可能影响结果的信息。因此任何两个查询在任何字符上的不同都会导致缓存不命中。此外,如果查询中包含任何用户自定义函数、存储函数、用户变量、临时表、MySQL库中的系统表,其查询结果也不会被缓存。
147
+ 如上,** 开启查询缓存后在同样的查询条件以及数据情况下,会直接在缓存中返回结果** 。这里的查询条件包括查询本身、当前要查询的数据库、客户端协议版本号等一些可能影响结果的信息。( ** 查询缓存不命中的情况:(1) ** ) 因此任何两个查询在任何字符上的不同都会导致缓存不命中。此外,( ** 查询缓存不命中的情况(2) ** ) 如果查询中包含任何用户自定义函数、存储函数、用户变量、临时表、MySQL库中的系统表,其查询结果也不会被缓存。
148
148
149
- 缓存建立之后,MySQL的查询缓存系统会跟踪查询中涉及的每张表,如果这些表(数据或结构)发生变化,那么和这张表相关的所有缓存数据都将失效。
149
+ (** 查询缓存不命中的情况(3)** )缓存建立之后,MySQL的查询缓存系统会跟踪查询中涉及的每张表,如果这些表(数据或结构)发生变化,那么和这张表相关的所有缓存数据都将失效。
150
+
151
+ ** 使用查询缓存的缺点/为什么MySQL8.0要移除这查询缓存?**
150
152
151
153
** 缓存虽然能够提升数据库的查询性能,但是缓存同时也带来了额外的开销,每次查询后都要做一次缓存操作,失效后还要销毁。** 因此,开启缓存查询要谨慎,尤其对于写密集的应用来说更是如此。如果开启,要注意合理控制缓存空间大小,一般来说其大小设置为几十MB比较合适。此外,** 还可以通过sql_cache和sql_no_cache来控制某个查询语句是否需要缓存:**
154
+
152
155
``` sql
153
156
select sql_no_cache count (* ) from usr;
154
157
```
@@ -159,7 +162,7 @@ select sql_no_cache count(*) from usr;
159
162
160
163
事务最经典也经常被拿出来说例子就是转账了。假如小明要给小红转账1000元,这个转账会涉及到两个关键操作就是:将小明的余额减少1000元,将小红的余额增加1000元。万一在这两个操作之间突然出现错误比如银行系统崩溃,导致小明余额减少而小红的余额没有增加,这样就不对了。事务就是保证这两个关键操作要么都成功,要么都要失败。
161
164
162
- ### 事物的四大特性 (ACID)
165
+ ### 事务的四大特性 (ACID)
163
166
164
167
![ 事物的特性] ( https://my-blog-to-use.oss-cn-beijing.aliyuncs.com/2019-6/事务特性.png )
165
168
You can’t perform that action at this time.
0 commit comments