资讯专栏INFORMATION COLUMN

PHP+Redis实战教程(5):hash散列类型

Invoker / 283人阅读

摘要:我们发现,第一个结果为第一个键值对的键,第二个结果为键值对的值,以此类推,每两个为一组。其结果为,少了两个结果,毕竟刚刚删除了一个键值对版本演示第一步,链接数据库我们先插入一个键值对到散列。原因即是,刚刚已经被删除

3、hash散列类型

简介

hash散列类似于一个小型的Redis数据库

一个散列可以包含多个键值对

散列的每个键都不能重复,各不相同,无序排列

其值可以是字符串或数字值

对于数字值,可以执行自增或者自减操作

散列结构

下面的结构中,user代表键名,其可以包含多个不同的键值对。

[
    "user":[
        "name1":"yanying1",
        "name2":"yanying2",
        "name3":"yanying3"
    ]
]

操作方法

命令 行为
hset 将指定的元素添加到散列
hget 获取指定的键的值
hgetall 获取散列所有的键值对
hdel 删除给定键
$redis->hset PHP版本,添加元素到散列
$redis->hget PHP版本,获取指定键的值
$redis->hgetall PHP版本,获取散列所有的键值对
$redis->hdel PHP版本,删除给定键

演示(命令行 + PHP演示)

命令行:

首先,我们添加一个键值对到散列。如果 成功则返回1;如果键已经存在,返回0

hset hash-key sub-key1 value1 // 返回 1

我们再添加一个不存在的键值对

hset hash-key sub-key2 value2 // 返回 1

这个时候,散列中已经存在键sub-key1sub-key2,接下来我们再添加一个相同的键sub-key1到散列中,看看会发生什么:

hset hash-key sub-key1 value1 // 返回 0,由于该键已经存在

下面我们通过hget获取一个给定键sub-key1的值。

hget hash-key sub-key1 // "value1"

成功获取了一个值。我们再获取添加的所有元素看看,刚刚的到底添加了哪几个值

hgetall hash-key

其结果如下。我们发现,第一个结果为第一个键值对的键,第二个结果为键值对的值,以此类推,每两个为一组。

"sub-key1"
"value1"
"sub-key2"
"value2"

下面我们试着删除一个键试试,我们会发现如果 该键之前存在于散列中,那么删除时候则返回1,否则,返回0

hdel hash-key sub-key1 // 该键之前存在于散列,返回1

我们再试着删除一次sub-key1,发现当删除 不存在的键的时候,返回结果0

hdel hash-key sub-key1

我们再次获取全部键值对,看看还剩些什么。

hgetall hash-key

其结果为,少了两个结果,毕竟刚刚删除了一个键值对

"sub-key1"
"value1"

PHP版本演示

第一步,链接redis数据库

$redis = new Redis();
$redis->connect("127.0.0.1", 6379);

我们先插入一个键值对到hash-key散列。1代表插入成功;0元素代表已经存在

$redis->hset("hash-key","sub-key1","value1"); // int 1,元素插入成功,之前不存在该键

我们再次插入相同键值对

$redis->hset("hash-key","sub-key1","value1"); // int 0,元素插入失败,该键已经存在

为了下面的演示使用,我们继续插入一些其他的值

$redis->hset("hash-key","sub-key2","value2"); // int 0

下面我们使用hget获取键对应的值。我们试试获取sub-key2的值。

$redis->hget("hash-key","sub-key2"); // "value2"

获取了一个后,我们在尝试使用hgetall获取刚刚插入的全部值,看看里面包含哪些键值对

$redis->hgetall("hash-key");

获得结果,是一个包含完整键值得数组

array (size=2)
  "sub-key1" => string "value1" (length=6)
  "sub-key2" => string "value2" (length=6)

查看完了所有的键值对,我们尝试删除其中一个键。 如果之前键存在于散列中,则返回1,反之,返回0

$redis->hdel("hash-key","sub-key1"); // 该键之前存在,返回int 1

我们再次尝试删除sub-key1键,发现其返回0. 则说明该键不存在集合中,删除失败

$redis->hdel("hash-key","sub-key1"); // 该键不存在,返回int 0

下面我们使用hgetall查看下散列中还剩余的所有键值对

$redis->hgetall("hash-key");

发现,只返回了包含一个键值对的数组。

array (size=1)
  "sub-key2" => string "value2" (length=6)
  

原因即是,刚刚sub-key1已经被删除

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/36237.html

相关文章

  • PHP+Redis实战教程5):hash散列类型

    摘要:我们发现,第一个结果为第一个键值对的键,第二个结果为键值对的值,以此类推,每两个为一组。其结果为,少了两个结果,毕竟刚刚删除了一个键值对版本演示第一步,链接数据库我们先插入一个键值对到散列。原因即是,刚刚已经被删除 3、hash散列类型 简介 hash散列类似于一个小型的Redis数据库 一个散列可以包含多个键值对 散列的每个键都不能重复,各不相同,无序排列 其值可以是字符串或数字值...

    Elle 评论0 收藏0
  • PHP+Redis实战教程(1):初识Redis

    摘要:本文为实战读书笔记简介是一个非关系型远程内存数据库,由于操作都在内存中,所以的速度非常快,性能十分强劲。同时,还可以自动的以两种不同的方式将数据库内容持久化到硬盘,保证数据的完整性。数据格式支持字符串列表集合散列有序集合数据类型。 本文为《Redis实战》读书笔记 Redis简介 Redis是一个非关系型远程内存数据库,由于操作都在内存中,所以Redis的速度非常快,性能十分强劲。 它...

    张迁 评论0 收藏0
  • PHP+Redis实战教程(1):初识Redis

    摘要:本文为实战读书笔记简介是一个非关系型远程内存数据库,由于操作都在内存中,所以的速度非常快,性能十分强劲。同时,还可以自动的以两种不同的方式将数据库内容持久化到硬盘,保证数据的完整性。数据格式支持字符串列表集合散列有序集合数据类型。 本文为《Redis实战》读书笔记 Redis简介 Redis是一个非关系型远程内存数据库,由于操作都在内存中,所以Redis的速度非常快,性能十分强劲。 它...

    jollywing 评论0 收藏0
  • Python--Redis实战:第一章:初识Redis:第二节:Redis数据结构简介

    摘要:上一篇文章实战第一章初识第一节简介下一篇文章实战第一章初识第三节你好文章投票试炼可以存储键与种不同的数据结构类型之间的映射,这中数据结构类别分别是字符串列表集合散列和有序集合。 上一篇文章:Python--Redis实战:第一章:初识Redis:第一节:Redis简介下一篇文章:Python--Redis实战:第一章:初识Redis:第三节:你好Redis-文章投票试炼 Redis可...

    FreeZinG 评论0 收藏0
  • Python--Redis实战:第一章:初识Redis:第二节:Redis数据结构简介

    摘要:上一篇文章实战第一章初识第一节简介下一篇文章实战第一章初识第三节你好文章投票试炼可以存储键与种不同的数据结构类型之间的映射,这中数据结构类别分别是字符串列表集合散列和有序集合。 上一篇文章:Python--Redis实战:第一章:初识Redis:第一节:Redis简介下一篇文章:Python--Redis实战:第一章:初识Redis:第三节:你好Redis-文章投票试炼 Redis可...

    ghnor 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<