PHP使用Redis的Hash(哈希表)命令

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 本篇笔记简单介绍了Redis的Hash(哈希表)命令:hDel,hExists,hGet,hGetAll,hIncrBy,hIncrByFloat,hKeys,hLen,hMGet,hMSet,hSet,HSetnx,hVals作用和php的使用

1.Hash(哈希表)命令

命令 作用 返回值
hDel 删除哈希表key中一个或多个字段,传入不存在的字段将被忽略 返回成功删除的字段数
hExists 判断哈希表key中是否存在给定的字段 存在true,不存在false
hGet 从哈希表key中获取给定的一个字段值 存在返回字段值,不存在返回false
hGetAll 从哈希表key中获取全部的字段和值 存在返回关联数组,不存在返回空数组
hIncrBy 整形数值递增(有符号) 递增后的值
hIncrByFloat 浮点型数值递增(有符号) 递增后的值
hKeys 返回哈希表key中所有的字段 存在字段返回关联数组,不存在返回空数组
hLen 返回哈希表key中字段数量 大于等于0的整数
hMGet 返回哈希表key中给定的一个或多个字段的值 返回一个关联数租,键为查询的字段,值为查询到的值,查询的字段不存在则值为false
hMSet 对哈希表key设置一组字段值 如果命令成功,返回true
hSet 对哈希表key设置一个字段值 如果是设置了一个新值,返回1,如果覆盖了一个旧值,返回0
HSetnx 在哈希表key中不存在给定字段的情况下赋值 成功返回1,如果已经存在则返回0
hVals 返回哈希表key中所有的字段的值 关联数组

2.在Hash的key中设置一个或多个字段值

<?php
/**
 * Created by PhpStorm.
 * User: jmsite.cn
 * Date: 2019/1/25
 * Time: 18:33
 */
try {
    $redis = new Redis();
    $redis->connect('192.168.75.132', 6379);
    //设置多个字段值
    $ret = $redis->hMSet('product_info_123', array(
        'product_id'            => 123,
        'product_name'          => 'Gregory登山包B75蓝色2015款',
        'product_price'         => 1700.00,
        'product_sales_volume'  => 10,
        'product_stocks'        => 20,
    ));
    var_dump($ret);
    //设置一个字段值
    $ret = $redis->hSet('product_info_123', 'product_feature', '一款背负系统极佳的登山包');
    var_dump($ret);
} catch (Exception $e){
    echo $e->getMessage();
}

执行结果

bool(true)
int(1)

3.设置Hash的过期时间,并获取Hash的字段值

try {
    $redis = new Redis();
    $redis->connect('192.168.75.132', 6379);
    //设置过期时间
    $ret = $redis->ttl('product_info_123');
    if ($ret === -1){
        $ret = $redis->expire('product_info_123', 3600);
        var_dump($ret);
    }
    //获取产品名称
    $ret = $redis->hGet('product_info_123', 'product_name');
    var_dump($ret);
    //获取价格和销量
    $ret = $redis->hMGet('product_info_123', array('product_price', 'product_sales_volume'));
    var_dump($ret);
} catch (Exception $e){
    echo $e->getMessage();
}

执行结果

bool(true)
string(32) "Gregory登山包B75蓝色2015款"
array(2) {
    ["product_price"]=>
  string(4) "1700"
    ["product_sales_volume"]=>
  string(2) "10"
}

4.变价,增加销量,减库存,获取全部字段值

try {
    $redis = new Redis();
    $redis->connect('192.168.75.132', 6379);
    //价格加15.99
    $ret = $redis->hIncrByFloat('product_info_123', 'product_price', 15.99);
    var_dump($ret);
    //销量加1
    $ret = $redis->hIncrBy('product_info_123', 'product_sales_volume', 1);
    var_dump($ret);
    //库存减1
    $ret = $redis->hIncrBy('product_info_123', 'product_stocks', -1);
    var_dump($ret);
    //获取全部字段值
    $ret = $redis->hGetAll('product_info_123');
    var_dump($ret);
} catch (Exception $e){
    echo $e->getMessage();
}

执行结果

float(1715.99)
int(11)
int(19)
array(6) {
    ["product_id"]=>
  string(3) "123"
    ["product_name"]=>
  string(32) "Gregory登山包B75蓝色2015款"
    ["product_price"]=>
  string(22) "1715.98999999999999999"
    ["product_sales_volume"]=>
  string(2) "11"
    ["product_stocks"]=>
  string(2) "19"
    ["product_feature"]=>
  string(36) "一款背负系统极佳的登山包"
}

5.字段相关操作

try {
    $redis = new Redis();
    $redis->connect('192.168.75.132', 6379);
    //判断字段product_feature和product_category是否存在
    $ret = $redis->hExists('product_info_123', 'product_feature');
    var_dump($ret);
    $ret = $redis->hExists('product_info_123', 'product_category');
    var_dump($ret);
    //获取字段长度
    $ret = $redis->hLen('product_info_123');
    var_dump($ret);
    //获取全部字段
    $ret = $redis->hKeys('product_info_123');
    var_dump($ret);
} catch (Exception $e){
    echo $e->getMessage();
}

执行结果

bool(true)
bool(false)
int(6)
array(6) {
    [0]=>
  string(10) "product_id"
    [1]=>
  string(12) "product_name"
    [2]=>
  string(13) "product_price"
    [3]=>
  string(20) "product_sales_volume"
    [4]=>
  string(14) "product_stocks"
    [5]=>
  string(15) "product_feature"
}

6.删除字段,获取所有字段值

try {
    $redis = new Redis();
    $redis->connect('192.168.75.132', 6379);
    //删除product_feature和product_stocks
    $ret = $redis->hDel('product_info_123', 'product_feature', 'product_stocks');
    var_dump($ret);
    //获取所有字段值
    $ret = $redis->hVals('product_info_123');
    var_dump($ret);
} catch (Exception $e){
    echo $e->getMessage();
}

执行结果

int(2)
array(4) {
    [0]=>
  string(3) "123"
    [1]=>
  string(32) "Gregory登山包B75蓝色2015款"
    [2]=>
  string(22) "1715.98999999999999999"
    [3]=>
  string(2) "11"
}

注意:商品价格变价后出现1715.98999999999999999是因为php精度问题造成的,需要使用php的round方法截取
原文地址:https://www.jmsite.cn/blog-609.html

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
4天前
|
存储 NoSQL Redis
Redis基础命令集详解
Redis基础命令集详解
11 1
|
4天前
|
存储 NoSQL Redis
Redis 常用命令
Redis 常用命令
13 0
|
5天前
|
存储 NoSQL Redis
深入浅出Redis(零):Redis常用命令的使用
深入浅出Redis(零):Redis常用命令的使用
|
5天前
|
存储 NoSQL 关系型数据库
深入浅出Redis(十二):Redis的排序命令Sort
深入浅出Redis(十二):Redis的排序命令Sort
|
6天前
|
NoSQL Linux Redis
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
21 0
|
9天前
|
存储 NoSQL 定位技术
Redis常用数据类型及常用命令
这些是Redis中常用的数据类型和命令。Redis还提供了许多其他命令和功能,用于数据存储、操作和查询。你可以根据需要选择适当的数据类型和命令来满足你的应用程序需求。
22 4
|
14天前
|
缓存 NoSQL PHP
【PHP 开发专栏】Redis 作为 PHP 缓存的解决方案
【4月更文挑战第30天】本文探讨了Redis作为PHP缓存的优势,如高性能、丰富数据结构、数据持久化和分布式支持。通过安装配置Redis、选择PHP客户端、执行读写操作及制定缓存策略实现缓存。应用场景包括页面、数据和会话缓存。但需注意数据一致性、过期时间、容量和安全问题,以确保应用稳定和安全。Redis能有效提升PHP应用响应速度和处理能力。
|
19天前
|
存储 NoSQL 算法
Redis入门到通关之Redis数据结构-Hash篇
Redis入门到通关之Redis数据结构-Hash篇
23 1
|
19天前
|
存储 NoSQL Java
Redis入门到通关之ZSet命令
Redis入门到通关之ZSet命令
18 0
|
19天前
|
存储 缓存 NoSQL
Redis入门到通关之Set命令
Redis入门到通关之Set命令
21 0