美文网首页
(11)查询CACHE第一部分

(11)查询CACHE第一部分

作者: suhuanzhen | 来源:发表于2016-11-30 11:00 被阅读0次

前面我们碰到过只是写一个查询语句,控制台输出信息中包含CACHE的情况。这个是rails内置的query cache,与页面缓存没关系,所以我们就算关闭了页面缓存,有的查询语句还是会有CACHE。下面根据简单例子和之前案例讲解CACHE。

rails的query cache的原理就是:在同一个请求周期内,如果没有update/delete/insert的操作,会对相同的sql查询进行缓存。

简单例子
  • 添加路由
get 'query_cache_one'
get 'query_cache_two'
get 'query_cache_three'
get 'query_cache_four'
get 'query_cache_five'
  • 添加动作
def query_cache_one
end
def query_cache_two
end
def query_cache_three
end
def query_cache_four
end
def query_cache_five
end

(1)第一种普通的情况,没有CACHE,有一条sql查询



(2)第二种普通的情况,没有CACHE,有两条sql查询



(3)第三种情况,产生CACHE


分析

第一种情况:
只有products=Product.limit(3)这条执行查询。后面products.each则是直接操作查询的结果集,针对的是结果集进行操作,所以不再继续执行查询。

第二种情况:
products=Product.limit(3)执行一条sql查询
Product.all.each也执行一条查询。
上一种情况products是结果集---我们直接对结果集each,不再执行查询。
而Product.all本身就是查询--我们执行该查询后each。
这就是本例中执行两条sql查询的原因。

第三种情况:
products=Product.limit(3)执行一条查询。而Product.limit(3).each不是直接对结果集products进行操作,而是执行Product.limit(3)的查询之后each,所以会有两条SQL语句。唯一与第二种情况不同的是第二条查询前面带有CACHE[0.0ms]。

这是因为rails的query cache就是:在同一个请求周期内,如果没有update/delete/insert的操作,会对相同的sql查询进行缓存。

第二种情况中,products=Product.limit(3)和Product.all翻译出来的sql是不一样的,一个带有LIMIT

SELECT  `products`.* FROM `products` LIMIT 3
SELECT `products`.* FROM `products`

第三种情况中,products=Product.limit(3)和Product.limit(3).each翻译出来的sql都是

SELECT  `products`.* FROM `products` LIMIT 3

Rails会对相同的sql查询进行缓存,所以本身代码跟第二种情况一样都是执行两条查询。但是这两条查询都是一样的,所以rails会进行sql缓存,第一条执行查询为Product Load,第二条查询使用query cache所以前面就有CACHE了。

不同方式实现相同sql的CACHE注意事项

同一个请求中相同SQL会使用query cache;判断SQL相同是根据控制台的翻译sql信息必须严格保持一致,比如下面两个动作,第一个动作我们是把Product.limit(3)在控制台的翻译sql复制到find_by_sql里面,sql语句一模一样所以识别为相同sql使用CACHE。



而虽然纯sql查询关键字大小写、空格这些都无所谓,但是rails的query cache笔记弱----必须要翻译后的sql大小写、空格这些都一样才识别为相同sql进而使用CACHE。
下面我们第一条sql是SELECT,而我们写的find_by_sql里面是select,大小写不同所以识别为不同的SQL(就是少一个空格也识别为不同的sql查询)。

提交到git仓库

我们直接在master分支提交

git add .
git commit -m "查询CACHE第一部分(顺便修改index.html.erb)"

相关文章

  • (11)查询CACHE第一部分

    前面我们碰到过只是写一个查询语句,控制台输出信息中包含CACHE的情况。这个是rails内置的query cac...

  • DNS解析步骤

    1.应用发起基于域名的请求后,linux先查询本地dns cache。 2.本地dns cache命中(cache...

  • 十分钟鸟瞰Druid

    Druid是个啥 Druid设计目标 快速查询 : 部分数据聚合 + Cache + 索引水平拓展能力:分布式列式...

  • 图片加载框架Picasso源码分析

    第一部分:代码整理 第二部分Action: 第三部分Cache: LruCache实现了Cache的所有方法。 第...

  • 分布式缓存(一)

    分布式缓存(一) 数据库缓存 Mysql 查询缓存(Query cache) 当打开了Query Cache功能,...

  • MySQL数据库性能优化

    MySQL架构 查询缓存 查询缓存(Query Cache)原理: 缓存SELECT操作或预处理查询的结果集和SQ...

  • 5. 查询缓存和索引

    1. 查询缓存 查询缓存( Query Cache )原理缓存SELECT操作或预处理查询的结果集和SQL语句,...

  • <--个人成长笔记系列-->零碎点...

    JAVA知识点: (掌握)SQL_CACHE 关键字,表示在MySQL中使用缓存查询;SQL_NO_CACHE...

  • mysql性能监控和sql语句

    1、查询缓存: 2、缓存在Cache中线程数量thread_cache_size: 3、DB已连接的线程数: 4、...

  • 关于MySQL的QC(QueryCache)的学习笔记

    Query Cache (查询缓存, 以下简称QC), 查询SELECT语句记起产生的数据结果, 如果以后遇到相同...

网友评论

      本文标题:(11)查询CACHE第一部分

      本文链接:https://www.haomeiwen.com/subject/bzozpttx.html