<?php //若是在find/findAll里传入了参数,则该参数即为key ORM::factory('article')->where('user_id', '=', '2')->and_where('created', '>', time() - 86400)->findAll(2); //上面的代码会在Model内部生成一个结构化的字符串,该字符串及对应的值将被放入缓存中 {table_name}-{key}-{md5(sql)} //相似这样 article-2-c81e728d9d4c2f636f067f89cc14862c //若是没有传参数,{key}就不会被替代 article-{key}-c81e728d9d4c2f636f067f89cc14862c //首次执行此代码时,ORM内部会先去缓存中找上面的结构化字符串,没有找到,就会执行SQL语句,而后把返回的结果的id放到缓存中 //这就是要放到缓存中的数据,下次若是再执行此SQL,直接从缓存中获取id(1,43,50),而后再从缓存中获取这些id对应的行内容 //注意到这里有个revision,这是未来要判断该缓存是否已过时的关键。 'article-2-c81e728d9d4c2f636f067f89cc14862c' => array( 'revision' => 1294476790, 'data' => [1, 43, 50], ); //同时还会生成另外一组数据,就是revision 'article-2-revision' => 1294476777, //若是做者又更新了一篇博客,则上面的查询语句结果就发生了变化。 ORM::factory('article')->values(array(...))->save(2); //ORM会找到缓存中的一组revision数据,同时更新它 'article-2-revision' => 1294476888, //若是没有提供key,那就是 'article-{key}-revision' => 1294476888, //下次再执行上面的ORM查询代码时,会先去查找'article-2-revision'的版本,而后跟'article-2-c81e728d9d4c2f636f067f89cc14862c'的版本号比较,若是前一个版本号>后一个版本号,表示数据有改变,缓存已过时,这时就须要从新执行SQL语句,并更新'article-2-c81e728d9d4c2f636f067f89cc14862c'这个字符串的版本号。若是比较结果是前一个版本号<=后一个版本号,那就直接从缓存中读取。