文档章节

NoSQL之Redis中的hash 操作

Heinrich_Chen
 Heinrich_Chen
发布于 2016/01/02 22:05
字数 933
阅读 85
收藏 3
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不存在,则先创建。
  127.0.0.1:6379> hset user name 
  127.0.0.1:6379> hset user name heinrich
    (integer) 0
    127.0.0.1:6379> hset user age 14
    (integer) 1
    127.0.0.1:6379> 
    如果存在返回0
    
    2, hsetnx
    
    设置hash field为指定值,如果key不存在,则先创建。如果field已经存在,返回0,nx是not exist的意思。
    127.0.0.1:6379> hset user age 14
    (integer) 1
    127.0.0.1:6379> hsetnx user name heinrich
    (integer) 0
    127.0.0.1:6379> hsetnx user name bob
    (integer) 0
    127.0.0.1:6379> hsetnx user weigth 20kg
    (integer) 1
    127.0.0.1:6379> 
    所有的redis操作都只需要关注key  和value无关,看上面就知道了
    
    3,  hmset 
      
    同时设置hash的多个field。
    127.0.0.1:6379> hmset user name gee age 12
    OK
    
    4, hget 
    
    获取指定的value值
     
    127.0.0.1:6379> hset user name gas
    (integer) 0
    127.0.0.1:6379> hget user name
    "gas"
    127.0.0.1:6379> hget user age
    "12"
    127.0.0.1:6379> 
    
    5,  hmget 
      
    获取全部指定的hash filed。
     127.0.0.1:6379> hmget user name age password
    1) "gas"
    2) "12"
    3) (nil)
    127.0.0.1:6379> 
    由于数据库没有field3,所以取到的是一个空值nil。
    
    6,  hincrby   
    
    指定的hash filed 加上给定值。 也可以说是做加减法操作  
    127.0.0.1:6379> hincrby user age 12
    (integer) 123456
    127.0.0.1:6379> hmget user name age 
    1) "gas"
    2) "12"
    127.0.0.1:6379>
    
    7,  hexists   
    
    测试指定field是否存在。
    127.0.0.1:6379> hexists user name
    (integer) 1
    127.0.0.1:6379> hexists user name1
    (integer) 0
    127.0.0.1:6379> 
    如果存在返回1不存在返回0
    
    8,  hlen
  返回指定hash的field数量。
  127.0.0.1:6379> hlen user
    (integer) 5
    
    9,  hdel   
    删除指定的对象中的元素并返回删除的hash的field数量。
    127.0.0.1:6379> hlen user
    (integer) 5
    127.0.0.1:6379> hdel user pwd
    (integer) 1
    127.0.0.1:6379> hmget user name age
    1) "gas"
    2) "12"
    127.0.0.1:6379> 
    当然我们的del可是万能的可以直接删除hashmap中的对象
    
    127.0.0.1:6379> hmset user name heinrich age 21 
    OK
    127.0.0.1:6379> hmget user name age
    1) "heinrich"
    2) "21"
    127.0.0.1:6379> del user
    (integer) 1
    127.0.0.1:6379> hmget user name age
    1) (nil)
    2) (nil)
    127.0.0.1:6379> 
    这就叫牛掰,完胜其他的del操作
    
    11,   hvals
       
    返回hash的所有value。
    127.0.0.1:6379> hmset user name heinrich age 21 pwd root
    OK
    127.0.0.1:6379> hvals user
    1) "heinrich"
    2) "21"
    3) "root"
    127.0.0.1:6379> 
    主管再也不用担心我的学习了
    但是看不到key,就像是找不到老婆,多难受
    
    12,  hgetall
    
     获取某个hash中全部的filed及value。 看到没就是这么牛掰,请记住不是hmgetall是hgetall
     
     127.0.0.1:6379> hgetall user
    1) "name"
    2) "heinrich"
    3) "age"
    4) "21"
    5) "pwd"
    6) "root"
    127.0.0.1:6379> 

   



     

     


© 著作权归作者所有

Heinrich_Chen
粉丝 14
博文 41
码字总数 39863
作品 0
杭州
高级程序员
私信 提问
redis&memcached&SQL&NoSQL

Why 一个应用肯定有两部分逻辑:数据逻辑和业务逻辑。 数据逻辑包括各种I/O,和内部的数据的处理,也就是在内部如何组织数据结构,变量也属于这一部分。 当一个应用变成一个进程,它负责数据逻...

backbye
02/24
0
0
NoSQL 2.0 要来临了吗?

基于“Key-Value”的数据库,例如 Cassandra, Redis 和 DynamoDB 已经在很多网络应用(例如 Twitter,Google,Facebook,LinkedIn 等等)中替代了传统了关系型数据库。但是这些 NoSQL 数据库...

虫虫
2012/03/09
5.4K
28
【DB】mongodb,redis,hbase 定位与区别

------------------------------------------------------------------------------------------------------ 【个人笔记】 我想在本地建立一个数据库,日常存取数据方便。常用语言为Python ...

CS青雀
03/06
0
0
企业级nosql数据库应用与实战-redis

企业级nosql数据库应用与实战-redis 项目场景: 随着互联网2.0时代的发展,越来越多的公司更加注重用户体验和互动,这些公司的平台上会出现越来越多方便用户操作和选择的新功能,如优惠券发放...

lc01081314
2018/06/26
0
0
LedisDB v0.1 发布,用Go实现的高性能NoSQL

高性能 NoSQL LedisDB v0.1 发布。 LedisDB 是一个底层采用LevelDB存储,用Go编写的高性能NoSQL,它在接口上面参考Redis,你可以很容易的从Redis进行迁移。 v0.1版本主要功能如下: 多种数据...

siddontang
2014/07/24
3.3K
11

没有更多内容

加载失败,请刷新页面

加载更多

二、Docker

1、Docker - The TLDR(Too Long,Don't Read,Linxu 终端工具 ) Docker是在Linux和Windows上运行的软件。它创建、管理和编排容器。该软件以开源方式开发,在Github上作为Moby开源项目的一部分。...

倪伟伟
25分钟前
2
0
Python猫荐书系列之七:Python入门书籍有哪些?

本文原创并首发于公众号【Python猫】,未经授权,请勿转载。 原文地址:https://mp.weixin.qq.com/s/ArN-6mLPzPT8Zoq0Na_tsg 最近,猫哥的 Python 技术学习群里进来了几位比较特殊的同学:一...

豌豆花下猫
今天
5
0
Guava RateLimiter限流源码解析和实例应用

在开发高并发系统时有三把利器用来保护系统:缓存、降级和限流 缓存 缓存的目的是提升系统访问速度和增大系统处理容量 降级 降级是当服务出现问题或者影响到核心流程时,需要暂时屏蔽掉,待高...

算法之名
今天
13
0
国产达梦数据库与MySQL的区别

背景 由于项目上的需要,把项目实现国产化,把底层的MySQL数据库替换为国产的达梦数据库,花了一周的时间研究了国产的数据库-达梦数据库,它和MySQL有一定的区别,SQL的写法也有一些区别。 ...

TSMYK
今天
2
0
老也有错?35岁程序员是一道坎,横亘在每个技术职场人的心中

随着互联网的高速发展变革,大龄恐惧症越来越多地在技术圈被人讨论。很多程序员在工作5-10年以后,都会开始思考5年、10年甚至更久以后的自己,会是怎样一种生活工作状态,以及是否会被时代抛...

我最喜欢三大框架
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部