V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
heraldboy
V2EX  ›  PHP

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

  •  
  •   heraldboy · 2016-01-19 21:39:23 +08:00 · 2463 次点击
    这是一个创建于 3023 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    6 条回复    2016-03-10 16:22:42 +08:00
    chaegumi
        1
    chaegumi  
       2016-01-19 22:48:45 +08:00
    想太多,直接用 cache driver 就好了
    wu1990
        2
    wu1990  
       2016-01-20 09:30:49 +08:00
    laravel
    heraldboy
        3
    heraldboy  
    OP
       2016-01-20 12:16:05 +08:00
    @chaegumi 不能很好的控制过期时间,感觉代码还是多了,如果像这样我就加个:->get_cache('key_users_favorites',60) 就可以缓存了。
    thenbsp
        4
    thenbsp  
       2016-01-20 15:28:21 +08:00
    这个完全可以实现,不过你需要修改 CI 的 DB 类的源码, DB 类的 QueryBuilder 最终是会转为 SQL 的。
    heraldboy
        5
    heraldboy  
    OP
       2016-01-20 19:55:38 +08:00
    @thenbsp 能扩展吗?最好不要动 CI
    thenbsp
        6
    thenbsp  
       2016-03-10 16:22:42 +08:00
    @heraldboy 理论可以,你可以试试继承 CI 的 DB 类,我没这么试过,你测一下。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1093 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 18:42 · PVG 02:42 · LAX 11:42 · JFK 14:42
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.