key-value

通过key获取或设置value

SET key value

GET key

SET server:name "fido"

GET server:name

SETNX : SET-if-not-exists

INCR : +1 原子操作

SET connections 10
INCR connections =>11 INCR A =>1

给key设置过期时间

TTL 获取一个key的存活时间,每次set一个key的value,过期时间将会重置

  • -2 已过期
  • -1 永不过期
SET str "ASD"
EXPIRE str 120 # 120s后过期
TTL str # 获取str的过期时间

list

RPUSH 插入数据到list末尾

LPUSH 插入数据到list起点

LRANGE 返回list的子集 下标从0开始

LRANGE friends 0 -1  # 类似python  返回整个list

LLEN 返回list长度

LPOP 删除list第一个元素并返回这个元素(左边是第一个元素)

RPOP 删除list最后一个元素并返回这个元素(右边是最后一个元素)

set

去重的list,无序,由于是无序的所以没有srange这个命令,取而代之的是SMEMBERS用于返回所有的数据

SADD

重复的元素会插入失败

SADD data_set "aa"    // 1
SADD data_set "data1" // 1
SADD data_set "aa" // 0,已经存在aa,插入失败

SREMset中删除指定元素

SREM data_set "data1"

SISMEMBER 是否set中元素 1 => 是

SISMEMBER data_set "aa"

SMEMBERS 返回set所有元素

SUNION 两个或多个set合并并返回所有元素的列表

SCARD 返回set长度

zset (有序set)

通过一个score来排序

添加数据的时候要指定一个score,用于排序,排序是redis自动执行的

ZADD superheros 1 ironman
ZADD superheros 3 thor
ZADD superheros 2 spiderman

ZRANGE key start stop [WITHSCORES]

返回key中[start stop] 的数据,按score递增排序,递减排序用ZREVRANGE

加上withscores后会将score也输出

> zrange superheros 0 -1
1) "ironman"
2) "spiderman"
3) "thor" > zrange superheros 0 -1 withscores
1) "ironman"
2) 1.0
3) "spiderman"
4) 2.0
5) "thor"
6) 3.0

ZREM

删除zset中一个或多个成员,不存在的被忽略

返回成功移除的数量

Hashes

HSET key field value

设置key中给定域field的值为value

HMSET key field value field2 value2

同时设置key的多个域

HGET key field

获取key的某个域的值

HMGET key field field2

获取key的多个域的值

> HSET key field value
(integer) 1 > HSET key field1 value1
(integer) 1 > HGET key field
"value" HMSET key field1 value1 field2 value2 field3 value3
OK > HMGET key field1 field2 filed3 field4
1) "value1"
2) "value2"
3) "value3"
4) (nil)

HSET的返回值

Sets field in the hash stored at key to value. If key does not exist, a new key holding a hash is created. If field already exists in the hash, it is overwritten.

0 变量已存在,值已更新

1 变量不存在,已经创建

理解为key指向了一个对象,这个对象里都是键值对

HINCRBY 为field的value增加指定数值,原子操作,如果field不存在将会新增

HSET key age 3
HINCRBY key age 2 # age变成5 HINCRBY key num 1 # num被新建,值设置为1

HDEL 删除key的某个field

HDEL key age

HGETALL 获取key的所有field和value

> HGETALL key
1) "field"
2) "value"
3) "field2"
4) "value2"

HLEN key

获取给定key中域的数量

HEXISTS key field

给定域中是否存在域field,返回0(不存在)或1(存在)

HKEYS key

类似keys,返回key中所有field

> hkeys key
1) "field"
2) "field2"

HVALS key

返回key中所有value

> hvals key
1) "value"
2) "value2"

Reference

  1. Try Redis

[Redis] Redis的基本数据结构的更多相关文章

  1. Redis中5种数据结构的使用场景介绍

    转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/108.html?1455861435 一.redis 数据结构使用场景 原 ...

  2. redis中5种数据结构的使用

    一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 ...

  3. Redis中的基本数据结构

    Redis基础数据结构 基础数据结构 sds简单动态字符串 数据结构 typedef struct sdstr{ int len // 字符串分配的字节 int free // 未使用的字节数 cha ...

  4. Redis中5种数据结构的使用场景

    一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 ...

  5. Redis 中 5 种数据结构的使用场景介绍

    这篇文章主要介绍了Redis中5种数据结构的使用场景介绍,本文对Redis中的5种数据类型String.Hash.List.Set.Sorted Set做了讲解,需要的朋友可以参考下 一.redis ...

  6. Redis所支持的数据结构

    1.启动Redis2.Redis所支持的数据结构 2.1.Redis常用操作 2.2.String类型及操作 2.3.Hash类型及操作 2.4.List类型及操作 2.5.Set类型及操作 2.6. ...

  7. Redis入门到高可用(四)—— Redis的五种数据结构的内部编码

    Redis的五种数据结构的内部编码

  8. redis的5种数据结构的使用场景介绍

    一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 ...

  9. Redis学习笔记之Redis中5种数据结构的使用场景介绍

    原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 redis 中一共有5种数据结构 ...

  10. 详细介绍Redis的几种数据结构以及使用注意事项(转)

    原文:详细介绍Redis的几种数据结构以及使用注意事项 1. Overview 1.1 资料 <The Little Redis Book>,最好的入门小册子,可以先于一切文档之前看,免费 ...

随机推荐

  1. Codeforces-450D-Jzzhu and Cities+dji

    参考:https://blog.csdn.net/corncsd/article/details/38235973 传送门:http://codeforces.com/problemset/probl ...

  2. “玲珑杯”ACM比赛 Round #18 1147 - 最后你还是AK了(思维,边的贡献)

    题目链接:http://www.ifrog.cc/acm/problem/1147 题解:这题很容易想到的是边的贡献也就是每条边最多被取到几次,和点的贡献类似,那些加边只要加在边贡献大的边上就行.然后 ...

  3. 1014 装箱问题 CODE[VS]

    1014 装箱问题 2001年NOIP全国联赛普及组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Descripti ...

  4. [USACO07OCT]障碍路线 & yzoj P1130 拐弯 题解

    题意 给出n* n 的图,A为起点,B为终点,* 为障碍,.可以行走,问最少需要拐90度的弯多少次,无法到达输出-1. 解析 思路:构造N * M * 4个点,即将原图的每个点分裂成4个点.其中点(i ...

  5. MPA JS CSS预处理方案

    1.WebPack 添加配置文件webpack.config.js,直接在当前目录运行 webpack. var basepath = '/root/webapps/happ'; var glob = ...

  6. 【Offer】[4] 【二维数组中的查找】

    题目描述 思路分析 Java代码 代码链接 题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数 ...

  7. java中最容易犯错的特殊字符

    问题背景 能准确说出下面的java 执行完毕后会打印出什么? System.out.println( String.class.getName()+ ".class"); Syst ...

  8. 自己在WEB学习过程中遇到的问题

    问题一: 下面这两段代码差别不大,为何test1结果不同: 代码1: public void doGet(HttpServletRequest request, HttpServletResponse ...

  9. Java多线程(十三):线程池

    线程池类结构 1.Executor是顶级接口,有一个execute方法. 2.ExecutorService接口提供了管理线程的方法. 3.AbstractExecutorService管理普通线程, ...

  10. Spring Security Oauth2 自定义 OAuth2 Exception

    付出就要得到回报,这种想法是错的. 前言 在使用Spring Security Oauth2登录和鉴权失败时,默认返回的异常信息如下 { "error": "unauth ...