文档参考:http://www.redis.net.cn/

string -   > key value                简单的keyvalue,常规计数:例如微博数,粉丝数

set        -> key value1 value2...            去重,所以保存用户的所有关注,粉丝。通过交集并集差集,可以实现共同关注,共同爱好等

sortedset   -> key score1 value1 score2 value2       排行榜,代权重的消息队列

hash   -> map [key1,value1    key2,value2...]    存对象,例如用户信息

list       -> 队列key    value1 ..value2...value3..     做分布式消息队列,最新消息排行

1.String 类型

重复会覆盖之前的key值

一个字符类型的key默认存储最大容量是512M

set key value       设置指定的key,value值

get key                 获取指定的key值

getrange key start end   返回key中包含头尾的子字符串

getset key value        设置指定的key,value 返回旧的value,如果没有旧value,返回(nil),并设置key value

setex key second value     设置key,value,并指定过期时间,单位为秒

psetex  key  milliseconds value           设置key,value,并指定过期时间,单位为毫秒

setnx key value     只有当不存在key时,才能设置成功

strlen  key    返回字符串的长度

incr key                 给key存储的数值加1,有原子性

incrby  key  increment          给key存储的数值指定加increment

incrbyfloat  key  increment   给key存储的数值指定加浮点类型

decr num           给key存储的数值减一

decrby num decrement          给key存储的数值减decrement

append key value       给key后追加字符

del key        删除key

mget  key1[key2]  获取多个键的值,可以减少网络传输

mset key value[key value]  可以设置多个键值

2.hash类型

字段名重复会覆盖之前的field的值

Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。

Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)

适合存储对象

person:

name:zhangsan

age:18

sex:男

hset key field value           设置哈希key中的field的值为value,可以设置多个

hget key field        获取哈希key中的field对应的value值

hgetall key         获取哈希key中所有的键值对

hexists key field        判断哈希key中对应的字段是否存在

hdel  key  field                          删除key中指定的字段

hincrby key field increment        给指定的哈希的字段数字增加increment

hincrbyfloat key field increment     给指定的哈希的字段数字增加浮点increment

hkeys key    获取哈希key中的所有字段

hlen    key    获取哈希key中字段的个数

hvals key   获取hash表中所有字段对应的值

hsetnx key field value   只有当field字段不存在,设置哈希表字段的值

3.list类型

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)

一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。

允许重复元素

可以实现分部式消息队列

lpush key value      将值插入列表头部,key是列表名,value是指

rpush key value      将值插入列表尾部

lrange key start stop    查询列表中的值,0 -1 表示所有

lpushx key value    向已存在的列表头部添加值

rpushx key value    向已存在的列表尾部添加至

lpop key    弹出左边第一个元素,并返回元素值

rpop key    弹出右边第一个元素,并返回元素值

llen key   获取列表长度

blpop key timeout      移除第一个元素,直到等待超时,或发现弹出为止

brpop key timeout   移除最后一个元素,直到等待超时,或发现弹出为止

4.set类型

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

sadd key value[value...]     向key集合中添加多个元素,如果存在,则会忽略存在的值,并返回成功加入的元素个数

scard key            获取key集合中元素个数

sdiff key1 [key2]         返回两个集合的差集

sdiffstore destination key1[key2]  将两个集合的差集存储到目标集合destination中

smembers key         返回集合中的所有成员

sinter key1 [key2]     返回两个集合的交集

sinter destination key1 [key2]     返回两个集合的交集并存储到目标集合

sunion key1[key2]           将所有集合的并集显示出来 

sunionstore destination key1[key2]      将所有集合的并集返回到destination中

sismember key value    判断value是不是key中的元素

spop key count     随机移除集合中的元素,count代表个数,返回移除的元素

.

srandmember key count    返回集合中count个随机值

srem key value[value]       移除集合中一个元素或多个元素

5.sortedSet类型

Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

有序集合的成员是唯一的,但分数(score)却可以重复。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)

zadd key score1 member1[score2 member2]   向key集合添加分数和成员

zcard key                  查看key集合中有几个元素

zrange key start end withscores        显示集合中start 到 end 集合并且显示分数

zcount key min max     计算集合元素中指定区间分数的成员数

zscore key value     返回指定成员的分数值

zrem key value      移除key集合中的指定成员

6.key 通用命令

keys *       查看所有的键

type key    获取键对应的类型

del key     删除指定的key

rename key newkey     修改key的名字

exists key        检查key是否存在

expire key seconds     给key设置过期时间,单位是秒

ttl key    查看还多少秒过期,-1为持久化

pttl key   查看还多久过期,单位毫秒

persist    去掉过期时间,持久化

move key bd   将当前的key移动到指定的数据库

发布订阅

publish channal message

subscribe channel [...]

<Redis> 入门二 五种数据类型的操作、通用key的操作、发布订阅的更多相关文章

  1. 【Redis】一、Redis简介及五种数据类型

    (一)Redis简介   Redis(Remote Dictionary Server)是一个使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value的开源 ...

  2. Redis支持的五种数据类型

    redis支持的五种数据类型: 1.string(字符串) 2.hash(哈希) Redis hash 是一个键值(key=>value)对集合. Redis hash是一个string类型的f ...

  3. Redis学习笔记(3)—— 五种数据类型&keys的通用操作

    一.Redis数据结构介绍 redis是一种高级的key-value的存储系统,其中的key是字符串类型,尽可能满足如下几点: 1)key不要太长,最好不要操作1024个字节,这不仅会消耗内存还会降低 ...

  4. 《闲扯Redis一》五种数据类型之String型

    一.前言 Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redis的开发和运维非常重要. ...

  5. Redis安装及五种数据类型

    redis是非关系型数据库,也叫内存数据库.数据是键值对的形式,通过key查找value 安装Radis:6379 sudo apt-get update sudo apt-get install r ...

  6. Redis学习笔记--五种数据类型的使用场景

    String 1.String 常用命令: 除了get.set.incr.decr mget等操作外,Redis还提供了下面一些操作: 获取字符串长度 往字符串append内容 设置和获取字符串的某一 ...

  7. redis的入门篇---五种数据类型及基本操作

    查看所有的key keys * 清空所有的key flushall 检查key是否存在 exists key 设置已存在的key的时长 expire key //设置key为10s 查看key还剩多少 ...

  8. 《闲扯Redis三》Redis五种数据类型之List型

    一.前言 Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redis的开发和运维非常重要. ...

  9. Redis五种数据类型应用场景

    目录 1.1 回顾 2.1 应用场景 2.1.1 String 2.1.2 Hash 2.1.3 List 2.1.4 Zet 2.1.5 zset 3.1 小结 1.1 回顾 Redis的五种数据类 ...

随机推荐

  1. 使用VS进行打包程序解决生成两个文件的问题(压缩后只有一个exe)

    使用VS打包创建setup相信大家都挺熟的了,不熟的话网上也有很多,就不做介绍了,现在给大家写下怎么将生成的那些文件夹以及setup.exe和.msi 文件打包成一个exe 我们这里使用的是Winra ...

  2. 洛谷 P4009 汽车加油行驶问题 【最小费用最大流】

    分层图,建k层,设(i,j,0)为点(i,j)的满油状态,全图的流量都是1,因为重复走到一个点没有意义.如果当前点是加油站,那么它向它上左的点连费用为a的边,向下右连费用为a+b的边: 否则,这个点的 ...

  3. 洛谷 P2766 最长不下降子序列问【dp+最大流】

    死于开小数组的WA?! 第一问n方dp瞎搞一下就成,f[i]记录以i结尾的最长不下降子序列.记答案为mx 第二问网络流,拆点限制流量,s向所有f[i]为1的点建(s,i,1),所有f[i]为mx(i+ ...

  4. 51nod 1227 平均最小公倍数【欧拉函数+杜教筛】

    以后这种题能用phi的就不要用mu-mu往往会带着个ln然后被卡常致死 把题目要求转换为前缀和相减的形式,写出来大概是要求这样一个式子: \[ \sum_{i=1}^{n}\sum_{j=1}^{i} ...

  5. AutoCAD2012启动错误 1308 源文件未找到

    启动AutoCAD2012时,弹出错误1308,如图所示: 是何原因? 对CAD的运行有何影响?

  6. Hdu 3605 Escape (最大流 + 缩点)

    题目链接: Hdu 3605  Escape 题目描述: 有n个人要迁移到m个星球,每个星球有最大容量,每个人有喜欢的星球,问是否所有的人都能迁移成功? 解题思路: 正常情况下建图,不会爆内存,但是T ...

  7. UVA Recurrences 矩阵相乘+快速幂

    题目大意: f(n) = a1 f(n - 1) + a2 f(n - 2) + a3 f(n - 3) + ... + ad f(n - d),已给递推公式,求f(n)的大小. 解题思路: n很大, ...

  8. STL之map基础知识

    Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候 ...

  9. Kruskal算法 分类: c/c++ 算法 2014-10-01 17:09 540人阅读 评论(0) 收藏

    Kruskal算法计算最小生成树,只与边有关,时间复杂度O(eloge) 步骤: 1.将边按权值递增排序 2.依次取出边加入最小生成树中并保证无环,判断是否成环可利用并查集. 例:http://ac. ...

  10. C#委托的用法 在C#中我想在一个方法中调用另一个按钮的事件,怎样来实现?

    最开始我也不清楚,后来我是这样想了. 1.事件和委托不是一个概念,你如果是调用control的事件,可以直接在其对应的事件eventhandler上attach自己的事件方法就好了如:this.But ...