我目前正在使用Redis缓存数据库结果。我所做的是将数据库结果放入一个数组中,并对数组进行序列化,然后将它们作为值添加到Redis缓存中的键中。
$res = $this->db->query($qry);
foreach($res->result() as $row) {
$curArr[] = $row;
}
$this->redis->set($key, serialize($curArr));
但是,每当我取消对缓存的序列化时,它都会在偏移量中返回一个错误。
$cache_result = $this->redis->get($key);
$curArr = unserialize($cache_result);
Message: unserialize(): Error at offset 8193 of 8701 bytes
当我检查$cache_result时,字符串的长度是8702,8194处的字符是";"。该部分的字符串片段为"Test 3''";s:7'。该字符串片段在$cache_result中也出现过多次,但错误仅出现在8193中。
非常感谢您的帮助!谢谢
为什么不这样做呢:
$res = $this->db->query($qry);
foreach($res->result() as $row)
{
$curArr[] = $row;
}
$this->redis->set($key, json_encode($curArr));
检索时:
$cache_result=$this->redis->get($key);
$curArr=json_decode($cache_result);