dongzi3805
2018-06-28 06:57 阅读 503
已采纳

如何在PHP中将数组数据存储到redis中

In my project, I want to store array data into redis.

Here I use PHP.

First, It connects to redis successfully. And then I defined a array which name should be info_g_1.

Last, I use mset function to store this arry.

Here is my php code:

<?php
$redis_obj = \common\Datasource::getRedis('instance1');//connect to redis successfully
$id = '1';
$r_goods = 'info_g_' . $id;
$r_goods = array(
 'sys_status' => 'one',
 'num_user' => 'two'
);

$redis_obj->mset($r_goods);

But unlucky, It works fail. Thers is no info_g_1 data in my redis.

    $redis_obj->sadd('info_g_'.$id,'one');
    $redis_obj->sadd('info_g_'.$id,'two');

and fetch data:

    $redis_obj->smembers('info_g_'.$id); //can get one and two.

But this way, I am not sure whether one belongs to sys_status or num_user.

Who can help me?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

1条回答 默认 最新

  • 已采纳
    duaeim2874 duaeim2874 2018-06-28 07:17

    The value in variable $r_goods is overwritten by array in next line in following code:

    $r_goods = 'info_g_' . $id;
    $r_goods = array(
     'sys_status' => 'one',
     'num_user' => 'two'
    );
    

    The actual value in $r_goods is:

    array(
         'sys_status' => 'one',
         'num_user' => 'two'
        );
    

    Also you can set it as:

    $redis_obj->set('info_g_' . $id, 'value to store');
    

    Update: To add multiple key-value pairs, mset can be used as set:

    $redis_obj->mset($r_goods);
    

    But if want to store array as values corresponding to key. Then need to json_encode array first & then set as follows:

    $redis_obj->set('key', json_encode(array('sys_status' => 'one', 'num_user' => 'two')));
    

    And can be retrieved as:

    $array = json_decode($redis_obj->get('key'), true);
    

    This reason behind this is, redis store only strings no other data type.

    点赞 评论 复制链接分享

相关推荐