【Redis3.0.x】数据类型
Redis3.0.x 数据类型
五大数据类型
- String(字符串)
- string 是 redis 最基本的类型。可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
- string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如 jpg 图片或者序列化的对象。
- string 类型是 Redis 最基本的数据类型。一个 redis 中字符串 value 最多可以是 512M。
- Hash(哈希)
- hash 是一个键值对集合。
- hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
- 类似 Java 里面的
Map<String, Object>。
- List(列表)
- list 是简单的字符串列表。按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
- 它是通过 链表 实现的。
- Set(集合)
- set 是 string 类型的无序集合。
- 它是通过 HashTable 实现的。
- ZSet(有序集合)
- zset 和 set 一样也是 string 类型元素的集合,且不允许重复的成员。
- 不同的是每个元素都会关联一个 double 类型的分数。
- redis 正是通过分数来为集合中的成员进行从小到大的排序。zset 的成员是唯一的,但分数(score)却可以重复。
key
常用 key 操作:
del key用于在 key 存在时删除 key。dump key序列化给定 key,并返回被序列化的值。exists key检查给定 key 是否存在。expire key seconds为给定 key 设置过期时间,以秒计。expireat key timestamp作用和 EXPIRE 类似,都用于为 key 设置过期时间。不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳。pexpire key milliseconds设置 key 的过期时间,以毫秒计。pexpireat key milliseconds-timestamp设置 key 过期时间的时间戳,以毫秒计。keys pattern查找所有符合给定模式(pattern)的 key 。move key db将当前数据库的 key 移动到给定的数据库 db 当中。persist key移除 key 的过期时间,key 将持久保持。pttl key以毫秒为单位,返回 key 的剩余的过期时间。ttl key以秒为单位,返回 key 的剩余的过期时间,-1 表示永不过期,-2 表示已过期。randomkey从当前数据库中随机返回一个 key 。rename key newkey修改 key 的名称。renamenx key newkey仅当 newkey 不存在时,将 key 改名为 newkey。scan cursor [MATCH pattern] [COUNT count]迭代数据库中的数据库键。type key返回 key 所储存的值的类型。
String
常用命令:
set key value设置指定 key 的值。get key获取指定 key 的值。getrange key start end返回 key 中字符串值的子字符getset key value将给定 key 的值设为 value ,并返回 key 的旧值(old value)。getbit key offset对 key 所储存的字符串值,获取指定偏移量上的位(bit)。mget key1 [key2…]获取所有(一个或多个)给定 key 的值。setbit key offset value对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)。setex key seconds value将值 value 关联到 key ,并将 key 的过期时间设为 seconds,以秒为单位。setnx key value只有在 key 不存在时设置 key 的值。setrange key offset value用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始。strlen key返回 key 所储存的字符串值的长度。mset key value [key value …]同时设置一个或多个 key-value 对。msetnx key value [key value …]同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。psetnx key milliseconds value将值 value 关联到 key ,并将 key 的过期时间设为 seconds,以毫秒为单位。incr key将 key 中储存的数字值增一。incrby key increment将 key 所储存的值加上给定的增量值(increment)。incrbyfloat key increment将 key 所储存的值加上给定的浮点增量值(increment) 。decr key将 key 中储存的数字值减一。decrby key decrement将 key 所储存的值减去给定的减量值(decrement) 。append key value如果 key 已经存在并且是一个字符串, 将指定的 value 追加到该 key 原来值(value)的末尾。
List
常用命令:
blpop key1 [key2 ] timeout移出并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。brpop key1 [key2 ] timeout移出并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。brpoplpush source destination timeout从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它;如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。lindex key index通过索引获取列表中的元素。linsert key before/after pivot value在列表的元素前或者后插入元素。llen key获取列表长度。lpop key移出并获取列表的第一个元素。lpush key value1 [value2]将一个或多个值插入到列表头部。lpushx key value将一个值插入到已存在的列表头部。lrange key start stop获取列表指定范围内的元素lrem key count value移除列表元素lset key index value通过索引设置列表元素的值ltrim key start stop对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。rpop key移除列表的最后一个元素,返回值为移除的元素。rpoplpush source destination移除列表的最后一个元素,并将该元素添加到另一个列表并返回。rpush key value1 [value2]在列表中添加一个或多个值。rpushx key value为已存在的列表添加值。
Set
常用命令:
sadd key member1 [member2]向集合添加一个或多个成员。scard key获取集合的成员数。sdiff key1 [key2]返回给定所有集合的差集。sdiffstore destination key1 [key2]返回给定所有集合的差集并存储在 destination 中。sinter key1 [key2]返回给定所有集合的交集。sinterstore destination key1 [key2]返回给定所有集合的交集并存储在 destination 中。sismember key member判断 member 元素是否是集合 key 的成员。smembers key返回集合中的所有成员。smove source destination member将 member 元素从 source 集合移动到 destination 集合。spop key移除并返回集合中的一个随机元素。srandmember key [count]返回集合中一个或多个随机数。srem key member1 [member2]移除集合中一个或多个成员。sunion key1 [key2]返回所有给定集合的并集。sunionstore destination key1 [key2]所有给定集合的并集存储在 destination 集合中。sscan key cursor [MATCH pattern] [COUNT count]迭代集合中的元素。
Hash
常用命令:
hdel key field1 [field2]删除一个或多个哈希表字段。hexists key field查看哈希表 key 中,指定的字段是否存在。hget key field获取存储在哈希表中指定字段的值。hgetall key获取在哈希表中指定 key 的所有字段和值。hincrby key field increment为哈希表 key 中的指定字段的整数值加上增量 increment。hincrbyfloat key field increment为哈希表 key 中的指定字段的浮点数值加上增量 increment。gkeys key获取所有哈希表中的字段。hlen key获取哈希表中字段的数量。hmget key field1 [field2]获取所有给定字段的值。hmset key field1 value1 [field2 value2 ]同时将多个 field-value(域-值)对设置到哈希表 key 中。hset key field value将哈希表 key 中的字段 field 的值设为 value。hsetnx key field value只有在字段 field 不存在时,设置哈希表字段的值。hvals key获取哈希表中所有值。hscan key cursor [MATCH pattern] [COUNT count]迭代哈希表中的键值对。
ZSet
常用命令:
zadd key score1 member1 [score2 member2]向有序集合添加一个或多个成员,或者更新已存在成员的分数。zcad key获取有序集合的成员数。zcount key min max计算在有序集合中指定区间分数的成员数。zincrby key increment member有序集合中对指定成员的分数加上增量 increment。zinterstore destination numkeys key [key …]计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中。zlexcount key min max在有序集合中计算指定字典区间内成员数量。zrange key start stop [WITHSCORES]通过索引区间返回有序集合指定区间内的成员。zrangebylex key min max [LIMIT offset count]通过字典区间返回有序集合的成员。zrangebyscore key min max [WITHSCORES] [LIMIT]通过分数返回有序集合指定区间内的成员。zrank key member返回有序集合中指定成员的索引。zrem key member [member …]移除有序集合中的一个或多个成员。zremrangebylex key min max移除有序集合中给定的字典区间的所有成员。zremrangebyrank key start stop移除有序集合中给定的排名区间的所有成员。zremrangebysocre key min max移除有序集合中给定的分数区间的所有成员。zrevrance key start stop[WITHSCORES] 返回有序集中指定区间内的成员,通过索引,分数从高到低。zrevrancebyscore key max min [WITHSCORES]返回有序集中指定分数区间内的成员,分数从高到低排序。zrevrank key member返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序。zscore key member返回有序集中,成员的分数值。zunionstore destination numkeys key [key …]计算给定的一个或多个有序集的并集,并存储在新的 key 中。zscan key cursor [MATCH pattern] [COUNT count]迭代有序集合中的元素(包括元素成员和元素分值)。
练习和总结
【Redis3.0.x】数据类型的更多相关文章
- linux安装redis-3.0.7
一.Redis介绍 1.简介 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类 ...
- Python并发编程-redis-3.0.5 源码安装
1.简介 Remote Dictionary Server(Redis)是一个基于 key-value 键值对的持久化数据库存储系统.redis 和 Memcached 缓存服务很像,但它支持存储的 ...
- redis-3.0.0安装
redis-3.0.0安装 前言 redis是常用的no-sql数据库,常用于缓存数据,同时,他也可以持久化数据.他是C语言开发的,所以安装的时候需要编译. 单机版redis yum install ...
- 【Redis3.0.x】事务
Redis3.0.x 事务 基本概念 multi,exec,discard,watch 是 Redis 事务的基础,它们允许一步执行一组命令,有两个重要保证: 事务中的所有命令都被序列化并顺序执行.在 ...
- 【Redis3.0.x】实战案例
Redis3.0.x 实战案例 简介 <Redis实战>的学习笔记和总结. 书籍链接 初识 Redis Redis 简介 Redis 是一个速度非常快的键值对存储数据库,它可以存储键和五种 ...
- Redis3.0 配置文件说明
背景: 以前有篇文章已经结果过了,现在复习一下,对Redis3.0进行说明: 参数说明: #redis.conf # Redis configuration file example. # ./red ...
- redis3.0.6安装(linux和windows)
官网上描述安装方法如下:$ wget http://download.redis.io/releases/redis-3.0.6.tar.gz$ tar xzf redis-3.0.6.tar.gz$ ...
- Redis3.0.1 Stable版本的集群部署(Mac)
本文档基于如下原始文档(CentOS)创建: http://blog.csdn.net/xu470438000/article/details/42971091 修改了一些路径的错误,补全了一些命令执 ...
- Redis3.0.7 cluster/集群 安装配置教程
1.前言 环境:CentOS-6.7-i386-LiveDVD 安装的CentOs系统 节点: 6个节点,3个主节点.3个从节点(由于redis默认需要3个主节点,如果想每个主节点有一个从节点,这是最 ...
随机推荐
- 【CH 弱省互测 Round #1 】OVOO(可持久化可并堆)
Description 给定一颗 \(n\) 个点的树,带边权. 你可以选出一个包含 \(1\) 顶点的连通块,连通块的权值为连接块内这些点的边权和. 求一种选法,使得这个选法的权值是所有选法中第 \ ...
- 自顶向下redis4.0(2)文件事件与客户端
redis4.0的文件事件与客户端 目录 redis4.0的文件事件与客户端 简介 正文 准备阶段 接受客户端连接 处理数据 返回数据结果 参考文献 简介 文件事件的流程大概如下: 在服务器初始化时生 ...
- IOS开发中设置导航栏主题
/** * 系统在第一次使用这个类的时候调用(1个类只会调用一次) */ + (void)initialize { // 设置导航栏主题 UINavigationBar *navBar = [UINa ...
- 多任务-python实现-使用队列完成进程间的通信(2.1.8)
@ 目录 1.为什么要使用队列 2.python代码实现 1.为什么要使用队列 进程之间是互相独立的,而线程能够共享全局变量 所以如果进程间想要交换数据的话 只有通过进程间的通信,比如socket.太 ...
- Android 安全研究 hook 神器frida学习(一)
在进行安卓安全研究时,hook技术是不可或缺的,常用的有Xposed:Java层的HOOK框架,由于要修改Zgote进程,需要Root,体验过Xposed,整个过程还是很繁琐的,并且无法hook,na ...
- Hello Python!用 Python 写一个抓取 CSDN 博客文章的简单爬虫
网络上一提到 Python,总会有一些不知道是黑还是粉的人大喊着:Python 是世界上最好的语言.最近利用业余时间体验了下 Python 语言,并写了个爬虫爬取我 csdn 上关注的几个大神的博客, ...
- tomcat能正常启动,但是http://localhost:8080/网页就是打不开,报404
问题描述: 在IDE中创建了一个新的Servers,并且加入一个Tomcat.然后启动服务,进入浏览器,输入localhost:8080进入,显示错误.服务是可以正常启动的,而且没有任何异常. 问题描 ...
- hive中笛卡尔积的优化
由于一个业务,必须要进行笛卡尔积,但是速度太慢了,left join时左表大概4万条数据,右表大概 3000多条数据,这样大概就是一亿多条数据, 这在大数据领域其实不算很大的数据量,但是hive中跑的 ...
- jsp文件导包
可以在一个页面中用上多个<% @ page %>指令,但是其中的属性只能用一次,不过也有个例外,那就是import属性.因为import属性和Java中的import语句差不多(参照Jav ...
- 什么是Service Mesh
摘自https://zhuanlan.zhihu.com/p/61901608 Service Mesh作为下一代微服务技术的代名词,初出茅庐却深得人心一鸣惊人,大有一统微服务时代的趋势. 那么到底什 ...