gpt4 book ai didi

php - 使用 Predis 存储表单数据

转载 作者:IT王子 更新时间:2023-10-29 06:15:40 26 4
gpt4 key购买 nike

我尝试使用 lpush

$list = "flavors";
$array = array($_GET["mainid"], $_GET["flavor1"], $_GET["flavor2"], $_GET["flavor3"]);
$redis = new Predis\Client();
$redis->lpush($list,implode("", $array));
echo $redis->lrange(0, -1);

我试过使用hset

$redis->hset("flavors", $_GET["mainid"], $_GET["mainid"]);
$redis->hset("flavors", $_GET['mainid'] . "flavor1", $_GET["flavor1"]);
$redis->hset("flavors", $_GET['mainid'] . "flavor2", $_GET["flavor2"]);
$redis->hset("flavors", $_GET['mainid'] . "flavor3", $_GET["flavor3"]);
echo $redis->hgetall($_GET['mainid']);

但我无法让它工作,因为我收到此错误:http://pastie.org/8401717

我该如何解决?我认为这是关于在它需要一个字符串时被赋予一个数组,但我在那里有 implode,那么为什么它不起作用?如果它根本无法工作,我还可以使用其他什么 Redis 数据类型?

最佳答案

您在使用 lpush 时遇到该错误,因为 flavors 键已经存储为不同的 Redis 数据类型。因此,您应该在重试之前删除该 key 。

您还以错误的方式使用了lpush。你应该试试这个:

foreach ($array as $value) {
$redis->lpush($list, $value);
}

或者如果你的 redis api 支持多参数:

call_user_func_array(array($redis, 'lpush'), array_merge($list, $array));

如果你想通过 mainid 存储 flavors,你可能想用多键存储它并使用 lpush:

$list = "flavor:{$_GET['mainid']}";
$redis->lpush($list, $_GET["flavor1"]);
$redis->lpush($list, $_GET["flavor2"]);
$redis->lpush($list, $_GET["flavor3"]);

另一种方法是存储在单个哈希中并使用 json_encode(不要使用 implode):

$data = json_encode(array($_GET["flavor1"], $_GET["flavor2"], $_GET["flavor3"]));
$redis->hset('flavors', $_GET["mainid"], $data);

关于php - 使用 Predis 存储表单数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19365826/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com