文档章节

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灵感
粉丝 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

没有更多内容

加载失败,请刷新页面

加载更多

通过ajax访问远程天气预报服务

http://www.webxml.com.cn/zh_cn/index.aspx 更改wsdl文件 打开文件将15行,51行,101行去掉 然后把文件复制到c盘 然后在桌面上面就生成了文件 将文件打成jar包 package cn.it.ws.weather;...

江戸川
今天
1
0
聊聊storm的tickTuple

序 本文主要研究一下storm的tickTuple 实例 TickWordCountBolt public class TickWordCountBolt extends BaseBasicBolt { private static final Logger LOGGER = LoggerFactory.getLogg......

go4it
今天
1
0
自动装箱和自动拆箱

自动装箱和自动拆箱 Java 提供了 8 种基本数据类型,每种数据类型都有其对应的包装类型,包装类是面向对象的类,是一种高级的数据类型,可以进行一些比较复杂的操作,它们是引用类型而不再基...

tsmyk0715
今天
2
0
简易审计系统

1、有时候我们需要对线上用户的操作进行记录,可以进行追踪,出现问题追究责任,但是linux自带的history并不会实时的记录(仅仅在内存中,当用户正常退出(exit logout )时才会记录到history文件里...

芬野de博客
今天
3
0
Qt那些事0.0.6

QML中使用Image,在设置source的后,通过Qt Quick2 Preview(qmlscene)遇到了图片找不到的问题: Image { id: success_img anchors.centerIn: parent ...

Ev4n
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部