Redis[三] @Hash 哈希
Redis的哈希值是字符串字段和字符串值之间的映射,所以他们是表示对象的完美数据类型
在Redis中的哈希值,可存储超过400十亿键值对。
redis 提供了2套操纵 一种是批量 一种是非批量
假设需要存储一个用户信息
批量操作
定义一个key为user1的hash 包含属性 name=xstao、age=22、sex=1、password=123 并获取user1中name的属性值
|
redis 127.0.0.1:6379[1]> hmset user1 name xstao age 22 sex 1 password 123
OK
redis 127.0.0.1:6379[1]> hmget user1 name
1) "xstao"
|
获取user1的全部key 、 value、全部的key value
|
redis 127.0.0.1:6379[1]> hgetall user1
1) "name"
2) "xstao"
3) "age"
4) "22"
5) "sex"
6) "1"
7) "password"
8) "123"
redis 127.0.0.1:6379[1]> hkeys user1
1) "name"
2) "age"
3) "sex"
4) "password"
redis 127.0.0.1:6379[1]> hvals user1
1) "xstao"
2) "22"
3) "1"
4) "123"
|
获取user1这个hash的字段数量
|
redis 127.0.0.1:6379[1]> hlen user1
(integer) 4
|
为hash user1添加一个字段 并查看添加后的数据结构
|
redis 127.0.0.1:6379[1]> hmset user1 ext1 test
OK
redis 127.0.0.1:6379[1]> hgetall user1
1) "name"
2) "xstao"
3) "age"
4) "22"
5) "sex"
6) "1"
7) "password"
8) "123"
9) "ext1"
10) "test"
|
更新key为user1 sex的值为0 并返回赋值成功后的新值
|
redis 127.0.0.1:6379[1]> hset user1 sex 0
(integer) 0
|
非批量
从命令格式上来看批量都加了m 而非批量都没有 比如批量hmset 非批量 hset
定义一个哈希表user2 第一次执行成功 ,第二次执行批量添加失败了。因为hset仅支持单个添加
|
redis 127.0.0.1:6379[1]> hset user2 name abc
(integer) 1
redis 127.0.0.1:6379[1]> hset user3 name abc age 2
(error) ERR wrong number of arguments for 'hset' command
redis 127.0.0.1:6379[1]>
|
其他一些常用命令命令
|
//判断user1中name是否存在 返回1表示已存在 返回0标识没有这个name字段key
redis 127.0.0.1:6379[1]> hexists user1 name
(integer) 1
//针对user1 中age(年龄)字段自增2 返回自增后的值
redis 127.0.0.1:6379[1]> hincrby user1 age 2
(integer) 24
//针对user1 中age(年龄)字段浮点数自增2.5 返回自增后的值
redis 127.0.0.1:6379[1]> hincrbyfloat user1 age 2.5
"28.5"
|

Redis[三] @Hash 哈希的更多相关文章
- 第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型
第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型 Hash操作,redis中Hash在内存中的存储格式如下图: hset(name, key, value)name ...
- 2、使用HashOperations操作redis(Hash哈希表)
文章来源:https://www.cnblogs.com/shiguotao-com/p/10560458.html 方法 c参数 s说明 Long delete(H key, Object... h ...
- Python操作redis系列以 哈希(Hash)命令详解(四)
# -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1. Hset 命令用于 ...
- 8、Redis五大数据类型---哈希(Hash)
一.哈希(Hash)简介: Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象. Redis hash 是一个键值对集合. 二.常用命令 1.h ...
- 后端利用Redis队列及哈希实现定时推送提醒的三个思路
周煦辰 2016年8月31日 本文介绍了一下本人在开发过程中遇到"定时推送提醒"的需求的时候所思考的三种解决方案. 明确问题 首先明确一下这个需求可能包含的几个"坑&qu ...
- redis:hash哈希类型的操作
1. hash哈希类型的操作 1.1. hset key field value 语法:hset key field value 作用:把key中field域的值设为value 注:如果没有field ...
- 面试官:说说Redis的Hash底层 我:......(来自阅文的面试题)
redis源码分析系列文章 [Redis源码系列]在Liunx安装和常见API 为什么要从Redis源码分析 String底层实现——动态字符串SDS Redis的双向链表一文全知道 前言 hello ...
- redis(三)-----redis基本数据类型
Redis的全称是REmote Dictionary Server,它主要提供了5种数据结构:字符串.哈希.列表.集合.有序集合,同时在字符串的基础之上演变 出了位图(Bitmaps)和HyperLo ...
- Hash哈希(一)
Hash哈希(一) 哈希是大家比较常见一个词语,在编程中也经常用到,但是大多数人都是知其然而不知其所以然,再加上这几天想写一个一致性哈希算法,突然想想对哈希也不是很清楚,所以,抽点时间总结下Hash知 ...
随机推荐
- (转)关于eclipse的TestNG的插件安装方法
背景:最近在学习spring 4.x时候,用到了testNG的测试方法,发现需要在eclipse安装testNG插件才能够正常进行单元测试. 1 插件安装 今天在配置eclipse+selenium+ ...
- (转)Maven项目标准目录结构
场景:工作中的项目都是使用Maven的目录结构,虽然能够如期的完成开发工作,但是对于一个Maven工程的配置却并不熟悉,这里主要介绍下Maven工程的而目录结构. 1 标准目录结构 src -main ...
- javascript中typeof和instanceof用法的总结
今天在看相应的javascript书籍时,遇到了typeof和instanceof的问题,一直不太懂,特地查资料总结如下: JavaScript 中 typeof 和 instanceof 常用来判断 ...
- R语言成功加载rJava方法
加载rJava的同时,要下载JAVA的JRE并且配置环境变量JAVA_HOME,因为rJava的调用需要java运行环境. 1.下载JRE 64位版本的JRE官网下载:http://www.java. ...
- 引水入城[NOI2010 ]
题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了 ...
- PyCharm中Directory与Python package的区别
对于Python而言,有一点是要认识明确的,python作为一个相对而言轻量级的,易用的脚本语言(当然其功能并不仅限于此,在此只是讨论该特点),随着程序的增长,可能想要把它分成几个文件,以便逻辑更加清 ...
- 特殊的ip地址
特殊IP地址 一.0.0.0.0 严格说来,0.0.0.0已经不是一个真正意义上的IP地址了.它表示的是这样一个集合:所有不清楚的主机和目的网络.这里的“不清楚”是指在本机的路由表里没有特定条目指明如 ...
- Unity 粒子系统 特效 移除屏幕外面后再移回来 不会显示问题
今天遇到的问题 勾选Particle System组件中的Sub Emitters属性 如图
- Loadrunner结果分析中连接图没有数据的设置
场景进行中,或者之后进行结果分析中,连接图表没有数据,取消选择标记选项.
- go的变量redeclare的问题,golang的一个小坑
go的变量声明有几种方式: 1 通过关键字 var 进行声明 例如:var i int 然后进行赋值操作 i = 5 2 最简单的,通过符号 := 进行声明和赋值 例如: i:=5 golang会 ...