php 的 codeigniter 框架能扩展数据库类实现链式方法的缓存吗

2016-01-19 21:39:23 +08:00
 heraldboy

能否实现下面类似的方法:
$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 秒。

2491 次点击
所在节点    PHP
6 条回复
chaegumi
2016-01-19 22:48:45 +08:00
想太多,直接用 cache driver 就好了
wu1990
2016-01-20 09:30:49 +08:00
laravel
heraldboy
2016-01-20 12:16:05 +08:00
@chaegumi 不能很好的控制过期时间,感觉代码还是多了,如果像这样我就加个:->get_cache('key_users_favorites',60) 就可以缓存了。
thenbsp
2016-01-20 15:28:21 +08:00
这个完全可以实现,不过你需要修改 CI 的 DB 类的源码, DB 类的 QueryBuilder 最终是会转为 SQL 的。
heraldboy
2016-01-20 19:55:38 +08:00
@thenbsp 能扩展吗?最好不要动 CI
thenbsp
2016-03-10 16:22:42 +08:00
@heraldboy 理论可以,你可以试试继承 CI 的 DB 类,我没这么试过,你测一下。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/251931

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX