能否实现下面类似的方法:
$row= $this->db->get_cache('key_users_favorites',60)->select('favorites')->get_where('users', array('uid'=>$uid))->row_array();
先查找 key_users_favorites 这个 key 的数据是否存在,存在则返回一个数组。
如果不存则继续原来的数据库查询,返回查询结果,并在这个 key 中保存数据 60 秒。
1
chaegumi 2016-01-19 22:48:45 +08:00
想太多,直接用 cache driver 就好了
|
2
wu1990 2016-01-20 09:30:49 +08:00
laravel
|
3
heraldboy OP @chaegumi 不能很好的控制过期时间,感觉代码还是多了,如果像这样我就加个:->get_cache('key_users_favorites',60) 就可以缓存了。
|
4
thenbsp 2016-01-20 15:28:21 +08:00
这个完全可以实现,不过你需要修改 CI 的 DB 类的源码, DB 类的 QueryBuilder 最终是会转为 SQL 的。
|