文档章节

redis03哈希

AllenOR灵感
 AllenOR灵感
发布于 2017/09/10 01:17
字数 1014
阅读 2
收藏 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灵感
粉丝 11
博文 2635
码字总数 83001
作品 0
程序员
私信 提问
Twemproxy增加或剔除Redis节点后对数据有何影响

本篇文章,Twemproxy增加或剔除Redis节点后对数据的影响是接着”通过Twemproxy代理Redis数据分片方案“这篇文章写的。最好还要懂一致性哈希(ketama)的原理。 上一篇文章中,我们配置了一个...

linuxprobe16
02/19
5
0
saltstack第三波《远程执行》

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

陈发哥007
2018/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
密码及加密方式

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

春哥大魔王的博客
2018/03/08
57
0
redis——哈希(hash)

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

Allenyan
2018/05/11
30
0

没有更多内容

加载失败,请刷新页面

加载更多

SpringBoot中 集成 redisTemplate 对 Redis 的操作(二)

SpringBoot中 集成 redisTemplate 对 Redis 的操作(二) List 类型的操作 1、 向列表左侧添加数据 Long leftPush = redisTemplate.opsForList().leftPush("name", name); 2、 向列表右......

TcWong
今天
3
0
排序––快速排序(二)

根据排序––快速排序(一)的描述,现准备写一个快速排序的主体框架: 1、首先需要设置一个枢轴元素即setPivot(int i); 2、然后需要与枢轴元素进行比较即int comparePivot(int j); 3、最后...

FAT_mt
昨天
4
0
mysql概览

学习知识,首先要有一个总体的认识。以下为mysql概览 1-架构图 2-Detail csdn |简书 | 头条 | SegmentFault 思否 | 掘金 | 开源中国 |

程序员深夜写bug
昨天
10
0
golang微服务框架go-micro 入门笔记2.2 micro工具之微应用利器micro web

micro web micro 功能非常强大,本文将详细阐述micro web 命令行的功能 阅读本文前你可能需要进行如下知识储备 golang分布式微服务框架go-micro 入门笔记1:搭建go-micro环境, golang微服务框架...

非正式解决方案
昨天
7
0
前端——使用base64编码在页面嵌入图片

因为页面中插入一个图片都要写明图片的路径——相对路径或者绝对路径。而除了具体的网站图片的图片地址,如果是在自己电脑文件夹里的图片,当我们的HTML文件在别人电脑上打开的时候图片则由于...

被毒打的程序猿
昨天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部