ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Redis hash数据类型的基本操作

2019-09-03 16:43:00  阅读:197  来源: 互联网

标签:127.0 hash 0.1 数据类型 redis myhash 6379 基本操作


Redis hash是一个string类型的field和value的映射表.它的添加、删除操作都是O(1)(平均)。hash特别适合用于存储对象。相较于将对象的每个字段存成单个string类型。将一个对象存储在hash类型中会占用更少的内存,并且可以更方便的存取整个对象。省内存的原因是新建一个hash对象时开始是用zipmap(又称为small hash)来存储的。这个zipmap其实并不是hash table,但是zipmap相比正常的hash实现可以节省不少hash本身需要的一些元数据存储开销。尽管zipmap的添加,删除,查找都是O(n),但是由于一般对象的field数量都不太多。所以使用zipmap也是很快的,也就是说添加删除平均还是O(1)。如果field或者value的大小超出一定限制后,Redis会在内部自动将zipmap替换成正常的hash实现. 这个限制可以在配置文件中指定
  hash-max-zipmap-entries 64 #配置字段最多64个。
  hash-max-zipmap-value 512 #配置value最大为512字节。
  1、hset
  设置hash field为指定值,如果key不存在,则先创建。
  redis 127.0.0.1:6379> hset myhash field1 Hello

(integer) 1

redis 127.0.0.1:6379>
  2、hsetnx
  设置hash field为指定值,如果key不存在,则先创建。如果field已经存在,返回0,nx是not exist的意思。
  redis 127.0.0.1:6379> hsetnx myhash field “Hello”

(integer) 1

redis 127.0.0.1:6379> hsetnx myhash field “Hello”

(integer) 0

redis 127.0.0.1:6379>
  第一次执行是成功的,但第二次执行相同的命令失败,原因是field已经存在了。
  3、hmset
  同时设置hash的多个field。
  redis 127.0.0.1:6379> hmset myhash field1 Hello field2 World

OK

redis 127.0.0.1:6379>
  4、hget
  获取指定的hash field。
  redis 127.0.0.1:6379> hget myhash field1

“Hello”

redis 127.0.0.1:6379> hget myhash field2

“World”

redis 127.0.0.1:6379> hget myhash field3

(nil)

redis 127.0.0.1:6379>
  由于数据库没有field3,所以取到的是一个空值nil。
  5、hmget
  获取全部指定的hash filed。
  redis 127.0.0.1:6379> hmget myhash field1 field2 field3

1) “Hello”

2) “World”

3) (nil)

redis 127.0.0.1:6379>
  由于数据库没有field3,所以取到的是一个空值nil。

6、hincrby
  指定的hash filed 加上给定值。
  redis 127.0.0.1:6379> hset myhash field3 20

(integer) 1

redis 127.0.0.1:6379> hget myhash field3

“20”

redis 127.0.0.1:6379> hincrby myhash field3 -8

(integer) 12

redis 127.0.0.1:6379> hget myhash field3

“12”

redis 127.0.0.1:6379>
  在本例中我们将field3的值从20降到了12,即做了一个减8的操作。
  7、hexists
  测试指定field是否存在。
  redis 127.0.0.1:6379> hexists myhash field1

(integer) 1

redis 127.0.0.1:6379> hexists myhash field9

(integer) 0

redis 127.0.0.1:6379>
  通过上例可以说明field1存在,但field9是不存在的。
  8、hlen
  返回指定hash的field数量。
  redis 127.0.0.1:6379> hlen myhash

(integer) 4

redis 127.0.0.1:6379>
  通过上例可以看到myhash中有4个field。
  9、hdel
  返回指定hash的field数量。
  redis 127.0.0.1:6379> hlen myhash

(integer) 4

redis 127.0.0.1:6379> hdel myhash field1

(integer) 1

redis 127.0.0.1:6379> hlen myhash

(integer) 3

redis 127.0.0.1:6379>
  10、hkeys
  返回hash的所有field。
  redis 127.0.0.1:6379> hkeys myhash

1) “field2”

2) “field”

3) “field3”

redis 127.0.0.1:6379>
  说明这个hash中有3个field。
  11、hvals
  返回hash的所有value。
  redis 127.0.0.1:6379> hvals myhash

1) “World”

2) “Hello”

3) “12”

redis 127.0.0.1:6379>
  说明这个hash中有3个field。
  12、hgetall
  获取某个hash中全部的filed及value。
  redis 127.0.0.1:6379> hgetall myhash

1) “field2”

2) “World”

3) “field”

4) “Hello”

5) “field3”

6) “12”

redis 127.0.0.1:6379>
  可见,一下子将myhash中所有的field及对应的value都取出来了。

标签:127.0,hash,0.1,数据类型,redis,myhash,6379,基本操作
来源: https://blog.csdn.net/yangbo787827967/article/details/100521736

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有