文档章节

redis03哈希

AllenOR灵感
 AllenOR灵感
发布于 2017/09/10 01:17
字数 1014
阅读 2
收藏 0
点赞 0
评论 0

字符串和哈希的区别

Redis是采用字典结构来存储数据的,比如字符串就是一个键 一个值

类似python中的{key: value}

哈希类型则可以理解为二级字典结构来存储数据,它的数据结构是键 字段 值

类似python中的{key: {subkey: value}}

思考:
从结构上看哈希类型比字符串类型多了一个二级嵌套;其实如果利用json.dumps和json.loads也可以在字符串的value中写入一个二级嵌套的键值对象(例如下面这段代码); 从单条数据且字段较少的案例上来看本质上没有什么区别,但是当一级字段数量较多时,处理每个二级字段哈希类型可以利用到redis的特性,而字符串类型只能加载出来由编程语言单独来进行处理。

import json
import redis
from _functools import partial

# 连接redis
r = redis.StrictRedis('192.168.1.124', decode_responses=True)

# 清空所有键
for number, key in enumerate(r.keys()):
    r.delete(key)

# 准备数据
r.set('str_computer', json.dumps({'cpu': 'i5', 'hd': 'ssd', 'memo': '8G'}))
r.hmset('hash_computer', {'cpu': 'i5', 'hd': 'ssd', 'memo': '8G'})


# 查看数据
for number, key in enumerate(r.keys()):
    if number == 0:
        print('{!s:<20}{!s:<30}{}'.format('数据类型', '键名', '值'))
    call = partial(lambda: '')
    if r.type(key) == 'string': call = partial(r.get, key)
    if r.type(key) == 'list': call = partial(r.lrange, *(key, 0, -1))
    if r.type(key) == 'hash': call = partial(r.hgetall, key)
    print('{!s:<20}{!s:<30}{}'.format(r.type(key), key, call()))


# 显示结果
'''
数据类型                键名                            值
hash                hash_computer                 {'cpu': 'i5', 'memo': '8G', 'hd': 'ssd'}
string              str_computer                  {"cpu": "i5", "memo": "8G", "hd": "ssd"}
'''

 

结构化 、 半结构化 、 非结构化

Redis既不是结构化数据也不是非结构化数据,它是半结构化数据。它为什么会被归类为半结构化数据。是因为数据的结构定义时有说明,能保存在数据库中的二维数据是结构化数据,而不能保存在数据库中的数据(例如:图片、文本、flask、exe文件等)是非结构化数据。Redis的数据既能和传统关系数据库一样保存二维数据,但又没有像关系型数据库那样限定死字段定义了之后就必须填写数据,因此向它这样能随意定义数据结构的二维数据库被称之为半结构化。

 

举例说明
关系型数据库定义了下面这样一张汽车资料表。

ID color name price
1 黑色 宝马 100万
2 白色 奥迪 90万
3 蓝色 宾利 600万

如果这个时候因为某种业务要求记录公司车辆资产已销售的车辆标记一个销售时间,那么一般的做法是在这张表上增加一个销售时间字段,那么整个表的结构将会变成下面这个样子。

ID color name price sold_at
1 黑色 宝马 100万 2017-04-20 15:53:53
2 白色 奥迪 90万
3 蓝色 宾利 600万

开个脑洞,对于ID2 和ID2这两辆车来说它们可能并不会卖掉,因为它们是公司要使用的车辆,所以对于它们两来说这个销售时间字段其实是冗余的。

 

那么在redis中并没有所谓的表字段的概念,所以就不会被这个东西约束;下面是列出redis是如何存储这种场景数据的。

import redis

# 连接redis数据库: 无密码
r = redis.StrictRedis(host='192.168.1.124', decode_responses=True)

# 清空所有键
for number, key in enumerate(r.keys()):
    r.delete(key)

# 定义数据
r.hmset('ID:1', {'color': '黑色', 'name': '宝马', 'price': '100万',
                  'data': '2017-04-20 16:06:06'})
r.hmset('ID:2', {'color': '白色', 'name': '奥迪',  'price': '90'})
r.hmset('ID:3', {'color': '蓝色', 'name': '宾利',  'price': '600万'})

# 获取数据
id_1, id_2, id_3 = r.hgetall('ID:1'), r.hgetall('ID:2'), r.hgetall('ID:3')

# 打印数据
print(id_1, id_2, id_3, sep='\n')

# 查看数据
{'name': '宝马', 'color': '黑色', 'price': '100万', 'data': '2017-04-20 16:06:06'}
{'name': '奥迪', 'color': '白色', 'price': '90'}
{'name': '宾利', 'color': '蓝色', 'price': '600万'}

参考

本文转载自:http://www.jianshu.com/p/ba69257f3416

共有 人打赏支持
AllenOR灵感
粉丝 10
博文 2634
码字总数 82983
作品 0
程序员
saltstack第三波《远程执行》

第3章 SaltStack远程执行 3.1 目标(Targeting) 指定目标,用来匹配minion,默认是以minion ID作为目标来匹配minion的。 匹配目标,非常重要,因为匹配错了,执行命令错了,后面会很严重的。...

陈发哥007
06/29
0
0
saltstack (2) 常用模块

1、crontab模块 [root@redis01-jp ~]# salt 'redis02-jp' cron.raw_cron root 查看指定用户的计划任务 redis02-jp: [root@redis01-jp ~]# salt 'redis02-jp' cron.set_job root '55' '14' '......

meteor_hy
2016/12/20
0
0
密码及加密方式

保护密码的最好方法是使用加盐哈希; 哈希算法 哈希算法是一种单向函数,把任意数量的数据转换成固定长度的“指纹”,这个过程无法逆转。如果输入发生一点改变,由此产生的哈希值完全不同。 ...

春哥大魔王的博客
03/08
0
0
VC++网络安全编程范例(7)-实现哈希摘要算法

哈希算法将任意长度的二进制值映射为固定长度的较小二进制值,这个小的二进制值称为哈希值。哈希值是一段数据唯一且极其紧凑的数值表示形式。如果散列一段明文而且哪怕只更改该段落的一个字母...

junwong
2012/03/09
0
0
redis——哈希(hash)

Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。 Redis 中每个 hash 可以存储 2^32 - 1 键值对(40多亿)。 hash命令 1、HDEL key field1 [field2....] 删除...

Allenyan
05/11
0
0
网络攻击技术(三)——Denial Of Service

1.1.1 摘要 最近网络安全成了一个焦点,除了国内明文密码的安全事件,还有一件事是影响比较大的——Hash Collision DoS(通过Hash碰撞进行的拒绝式服务攻击),有恶意的人会通过这个安全漏洞...

长平狐
2012/06/11
123
0
哈希表与应用

一、哈希表 哈希表是一种数据结构,它需要配合哈希函数使用,用于建立索引,便于快速查找。 哈希表的实现一般来说就是一个定长的存储空间,每个位置存储一个对象。如果我们假设定长为N,则可...

不死的达芬奇
2016/12/21
28
0
Effective Java 2.0_中文版_Item 9

文章作者:Tyan 博客:noahsnail.com | CSDN | 简书 Item 9: 重写时必须重写 一个常见的错误来源是没有重写方。在每个重写方法的类中,你必须重写方法。不这样做会违反的通用约定,这会使你的...

Quincuntial
2016/12/02
0
0
.NET哈希函数包--KinsHash

哈希函数是现代密码系统的基础。 这些函数将任意长度的二进制字符串映射为固定长度的小二进制字符串(称为哈希值)。 加密哈希函数有这样一个属性:在计算时不可能将两个不同的输入通过哈希算...

匿名
2010/05/28
1K
0
【Redis基本数据结构】字典实现 rehash介绍

字典, 又称为符号表 关联数组或者映射,是一种保存键值对的抽象数据结构. 字典作为一种常用数据结构被内置在许多程序语言中,由于 C 语言没有内置这种数据结构, Redis 构建了自己的字典实现. 字...

xiaomin0322
03/01
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

微服务架构下的安全认证与鉴权

微服务下常见认证解决方案; OAuth认证与授权; JWT认证介绍; Spring Cloud的OAuth2实现; 单体应用转变为分布式应用 单体应用转变为分布式应用在架构方式上存在较大区别,单体应用下的简单...

Java大蜗牛
30分钟前
0
0
前端面试题汇总

最近在复习,准备找工作了,特此总结一下前端的相关知识。 1.获取浏览器URL中查询字符的参数: function getQuery(name){    var reg = new RegExp("(^|&)"+name+"=([^&]*)"(&|$));...

凛冬来袭
30分钟前
0
0
可持续发展的学习道路

与其要求别人,不如提升自己 内心渴望进步 经常做出改变现有模式,不断学习 寻找资源,整合资源,不断熟练这种模式 渠道很重要 先打开新世界的航路

狮子狗
35分钟前
0
0
apollox-lua开源项目 示例codepen2

今天在示例上增加了几个功能, 首先添加js array的标准库。 所有js array的方法目前都支持了。 添加查看code模式。 点击查看code可以看到生成的lua代码。默认web模式需要把标准库连接进来, ...

钟元OSS
50分钟前
0
0
javascript性能优化之避免重复工作

javascript最重要也最根本的性能优化标准之一是避免工作,避免工作又包括两点,第一,不做不必要的工作,第二,不做重复的已经完成的工作。第一部分可以通过代码重构完成,第二部分不做重复的...

老韭菜
今天
0
0
缓存穿透、并发和雪崩那些事

0 题记 缓存穿透、缓存并发和缓存雪崩是常见的由于并发量大而导致的缓存问题,本文讲解其产生原因和解决方案。 缓存穿透通常是由恶意攻击或者无意造成的;缓存并发是由设计不足造成的;缓存雪...

Java填坑之路
今天
1
0
项目jar包管理构建工具---Maven

一、what is Maven? 我们来寻找一下官网,里面介绍了maven到底是什么?下面一句话就有讲解到:Apache Maven is a software project management and comprehension tool. Based on the conc...

一看就喷亏的小猿
今天
0
0
JVM学习手册(一):查看堆内存使用情况以及排错

平时出现内存溢出以及死锁,一般处理方式都是查看日志,找到抛出异常的代码行,然后本地分析代码,但是这样对于线上排查十分糟糕,这段时间在研究JVM发现了几个比较好的工具和指令. 1.针对频繁GC和...

勤奋的蚂蚁
今天
1
0
17.TCP:传输控制协议

介绍 TCP和UDP使用同一网络层(IP),但TCP提供了面向连接、可靠的传输层服务 TCP传输给IP层的信息单位称为报文段或段 TCP通过如下方式保证可靠性: 应用数据被分割成TCP认为最合适发送的数据...

loda0128
今天
0
0
重装Oracle时出现environment variable "PATH"错误的解决办法

在win7 64位下重新安装oracle 11g,一直报environment variable "PATH"的错误,按说明将path里多余的路径删除,但没办法解决。选择忽略错误继续安装,装一半会报CRC错误,还是安装失败。最好...

良言
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部