嗨,我正在与Redis一起使用Laravel。当我试图通过get方法访问一个键时,然后得到以下错误“对持有错误类型值的键进行操作”
我使用以下代码访问键值-
我使用这段代码从redis获取数据
$values = "l_messages"; $value = $redis->HGETALL($values); print($value);
此错误意味着键"l_messages"索引的值不是hash类型,而是其他类型。在前面的代码中,您可能已经将它设置为另一个值。尝试其他各种值获取命令,从GET开始,看看哪个有效,您就会知道这里实际上是什么类型。
hash
Redis支持6种数据类型。您需要知道键映射到什么类型的值,对于每种数据类型,检索它的命令都是不同的。
下面是检索键值的命令:
<key>
<key> <start> <end>
<key> <min> <max>
<count>
<ID>
使用TYPE命令检查键映射到的值的类型:
TYPE
当我试图将某些东西设置为redis时,我遇到了这个问题。问题是我之前使用了“set”;方法用某个键设置数据,如
$redis->set('persons', $persons)
后来我决定改为“hset”;方法,我尝试了这种方法
foreach($persons as $person){ $redis->hSet('persons', $person->id, $person); }
然后我得到了前面提到的错误。所以,我要做的就是去redis-cli,手动删除“persons"入口与
del persons
它只是不能在现有的键下写不同的数据结构,所以我必须删除条目和hSet。
此错误表示您试图将错误的值推入键,这意味着已经存在相同的键,但具有不同的数据结构。
要获得所有的键做这个在redis cli
keys *
这应该显示所有的键 现在要获取键存储的值的类型,执行
type <key>
,它表示你可以将什么值压入键。 在我的情况下,类型是字符串(使用集),我试图使用键作为列表
数据库索引错误
有时是因为你在一个错误的db编号。我也有同样的问题,把db改成了正确的,没有问题,它工作了!我建议你在HGETALL或任何你想要的之前,选择正确的数据库,或者至少考虑你在哪个数据库中。
这不是PHP,但我在c#中有类似的问题,并使用此页作为参考来解决这个问题。
我的。net Core 3.1 web服务器的IDistributedCache.SetStringAsync实际上是将数据存储为hash而不是string;我使用KeyTypeAsync确认了这一点。不用说,这非常令人困惑。它似乎将配置DistributedCacheEntryOptions存储为散列的一部分,而{data}是原始字符串的子键。
IDistributedCache.SetStringAsync
string
KeyTypeAsync
DistributedCacheEntryOptions
{data}
要解决此问题,您需要将其读取为哈希并手动访问子键,而不是将其读取为字符串。参见以下代码:
var str = (await redisConnection.GetDatabase().HashGetAllAsync("stringKey"))?.LastOrDefault()?.Value?.ToString();