php – fetch当我从缓存中获取它时只返回一行

前端之家收集整理的这篇文章主要介绍了php – fetch当我从缓存中获取它时只返回一行前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在尝试采用缓存类在我的网页上使用.

简单的逻辑是这样的:

尝试从缓存中获取数据:

>如果没有:运行查询并将其设置为缓存.
>如果有:显示来自缓存的数据.

我的代码

PHP
// Require Library
require_once("PHPfastcache.PHP");
$cache = PHPFastCache();

//lets get it from cache.
$r = $cache->get("cachethis");

if($r == null) {

    echo " THIS TIME RUN WITHOUT CACHE 404_16@

我的输出和问题

我有两排.

当我从查询获取它们时,我的代码输出它们.这很好.

row1
row2
@H_404_16@

但是当页面从缓存中将它带给我时,它只输出最后一行.

row2
@H_404_16@

我试过的

我尝试使用fetchAll()函数而不是fetch()但这次我收到通知:未定义索引:id错误.

所以我被困住了,需要你的帮助.

最佳答案
如果一次为所有记录,请使用fetchAll

$r = $cache->get("cachethis");

if(!is_array($r)) {
    // not in cache,from db
    $query = $handler->query("SELECT * FROM members");
    $r = $query->fetchAll(PDO::FETCH_ASSOC);
    $cache->set("cachethis",10);
}

foreach($r as $v) echo $v['id']."404_16@

猜你在找的MySQL相关文章