Redis实战《红丸出品》2.3 hashes类型及操作
2012-06-15 22:55
281 查看
2.3
hashes类型及操作
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字节
2.3.1 hset
设置hash field为指定值,如果key不存在,则先创建。
redis 127.0.0.1:6379> hset myhash field1 Hello (integer) 1 redis 127.0.0.1:6379> |
设置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> |
2.3.3 hmset
同时设置hash的多个field。
redis 127.0.0.1:6379> hmset myhash field1 Hello field2 World OK redis 127.0.0.1:6379> |
获取指定的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> |
2.3.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> |
2.3.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> |
2.3.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> |
2.3.8 hlen
返回指定hash的field数量。
redis 127.0.0.1:6379> hlen myhash (integer) 4 redis 127.0.0.1:6379> |
2.3.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> |
返回hash的所有field。
redis 127.0.0.1:6379> hkeys myhash 1) "field2" 2) "field" 3) "field3" redis 127.0.0.1:6379> |
2.3.11 hvals
返回hash的所有value。
redis 127.0.0.1:6379> hvals myhash 1) "World" 2) "Hello" 3) "12" redis 127.0.0.1:6379> |
2.3.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> |
----------------------------------------------------------------------------------------------------------------
《MongoDB管理与开发精要》、《Redis实战》作者
@CD红丸 http://weibo.com/u/2446082491
相关文章推荐
- Redis实战《红丸出品》2.1 Redis数据类型及操作前言
- Redis实战《红丸出品》2.2 strings类型及操作
- Redis实战《红丸出品》2.4 lists类型及操作
- Redis实战《红丸出品》2.5 sets类型及操作
- Redis实战《红丸出品》2.6 sorted sets类型及操作
- Redis实战《红丸出品》2.1 Redis数据类型及操作前言
- Redis详解:hashes数据类型及操作
- redis 学习手册之哈希表数据类型hashes操作命令
- redis--hashes类型及操作
- Redis实战(4)数据类型二Hashes
- Redis数据类型及其操作—Hashes
- Redis详解:hashes数据类型及操作
- Redis之hashes类型及操作
- redis实战基础篇:redis的5种数据类型的基本操作
- redis操作二(hashes类型及操作)
- Redis详解:hashes数据类型及操作
- Python操作redis(二)hash类型
- Redis有序集合数据类型操作命令
- Redis的数据类型及操作(三):set类型
- Redis入门教程:特性及数据类型的操作