2019独角兽企业重金招聘Python工程师标准>>>

数据类型——String

存储 :

  • 形如: set key value          set name aobama

获取:

  • 形如: get key      get name

删除

  • 形如: del key      del name

自增或者自减

  • 形如: incr key

incr age  : 如果age的key不存在, 那么会创建这个key 并且对应的值为1.

  • incrby key 数字 : 意思是累加后面的数字值。

incrby age 5  若没有这个key,那么会创建并赋值。

decrby age 5  减去后面的数值

append key value  拼接字符串

append name aa  : 在name的原先字符串基础上累加aa字符串

keys * 查看所有key

设置/获取多个键值

  • mset k1 v1 k2 v2 k3 v3
  • mget k1 k3

获取字符串长度

  • strlen str

127.0.0.1:6379> strlen str

(integer) 0

127.0.0.1:6379> set str hello

OK

127.0.0.1:6379> strlen str

(integer) 5

数据类型——Hash

hash叫散列类型,它提供了字段和字段值的映射。字段值只能是字符串类型,不支持散列类型、集合类型等其它类型。如下:

赋值

HSET命令不区分插入和更新操作,当执行插入操作时HSET命令返回1,当执行更新操作时返回0。

一次只能设置一个字段值  HSET key field value

        127.0.0.1:6379> hset user username zhangsan

        (integer) 1

一次可以设置多个字段值  HMSET key field value [field value ...]  

        127.0.0.1:6379> hmset user age 20 username lisi

        OK

当字段不存在时赋值,类似HSET,区别在于如果字段存在,该命令不执行任何操作 HSETNX key field value

         127.0.0.1:6379> hsetnx user age 30        如果user中没有age字段则设置age值为30,否则不做任何操作

        (integer) 0

一次只能获取一个字段值   HGET key field

        127.0.0.1:6379> hget user username

        "zhangsan“

一次可以获取多个字段值  HMGET key field [field ...]

        127.0.0.1:6379> hmget user age username

        1) "20"

        2) "lisi"  

获取所有字段值     HGETALL key

        127.0.0.1:6379> hgetall user

        1) "age"

        2) "20"

        3) "username"

        4) "lisi"

可以删除一个或多个字段,返回值是被删除的字段个数   HDEL key field [field ...]

        127.0.0.1:6379> hdel user age

        (integer) 1

        127.0.0.1:6379> hdel user age name

        (integer) 0

        127.0.0.1:6379> hdel user age username

        (integer) 1

增加数字   HINCRBY key field increment

        127.0.0.1:6379> hincrby user age 2         将用户的年龄加2

        (integer) 22

        127.0.0.1:6379> hget user age                 获取用户的年龄

        "22“

判断字段是否存在   HEXISTS key field

        127.0.0.1:6379> hexists user age             查看user中是否有age字段

        (integer) 1

        127.0.0.1:6379> hexists user name         查看user中是否有name字段

        (integer) 0

只获取字段名或字段值  HKEYS key        HVALS key

        127.0.0.1:6379> hmset user age 20 name lisi

        OK

        127.0.0.1:6379> hkeys user

        1) "age"

        2) "name"

        127.0.0.1:6379> hvals user

        1) "20"

        2) "lisi"

获取字段数量   HLEN key

        127.0.0.1:6379> hlen user

        (integer) 2

数据类型——List

Arraylist和linkedlist的区别

  1. Arraylist是使用数组来存储数据,特点:查询快、增删慢
  2. Linkedlist是使用双向链表存储数据,特点:增删快、查询慢,但是查询链表两端的数据也很快。

Redis的list是采用来链表来存储的,所以对于redis的list数据类型的操作,是操作list的两端数据来操作的。

向列表左边增加元素   LPUSH key value [value ...]

127.0.0.1:6379> lpush list:1 1 2 3

(integer) 3

向列表右边增加元素   RPUSH key value [value ...]

127.0.0.1:6379> rpush list:1 4 5 6

(integer) 3

LRANGE命令是列表类型最常用的命令之一,获取列表中的某一片段,将返回start、stop之间的所有元素(包含两端的元素),索引从0开始。索引可以是负数,如:“-1”代表最后边的一个元素。LRANGE key start stop

127.0.0.1:6379> lrange list:1 0 2

1) "2"

2) "1"

3) "4"

127.0.0.1:6379> lrange list1 0 -1

从列表两端弹出元素

LPOP命令从列表左边弹出一个元素,会分两步完成:

第一步是将列表左边的元素从列表中移除

第二步是返回被移除的元素值。

LPOP key

RPOP key

127.0.0.1:6379> lpop list:1

"3“

127.0.0.1:6379> rpop list:1

"6“

获取列表中元素的个数  LLEN key

127.0.0.1:6379> llen list:1

(integer) 2

删除列表中指定的值: LREM key count value      LREM命令会删除列表中前count个值为value的元素,返回实际删除的元素个数。根据count值的不同,该命令的执行方式会有所不同:

  • 当count>0时, LREM会从列表左边开始删除。
  • 当count<0时, LREM会从列表后边开始删除。
  • 当count=0时, LREM删除所有值为value的元素

获得/设置指定索引的元素值:  LINDEX key index

127.0.0.1:6379> lindex l:list 2

"1"

设置指定索引的元素值  LSET key index value

127.0.0.1:6379> lset l:list 2 2

OK

127.0.0.1:6379> lrange l:list 0 -1

1) "6"

2) "5"

3) "2"

4) "2"

只保留列表指定片段   指定范围和LRANGE一致    LTRIM key start stop

127.0.0.1:6379> lrange l:list 0 -1

1) "6"

2) "5"

3) "0"

4) "2"

127.0.0.1:6379> ltrim l:list 0 2

OK

127.0.0.1:6379> lrange l:list 0 -1

1) "6"

2) "5"

3) "0"

向列表中插入元素  LINSERT key BEFORE|AFTER pivot value

该命令首先会在列表中从左到右查找值为pivot的元素,然后根据第二个参数是BEFORE还是AFTER来决定将value插入到该元素的前面还是后面

127.0.0.1:6379> lrange list 0 -1

1) "3"

2) "2"

3) "1"

127.0.0.1:6379> linsert list after 3 4

(integer) 4

127.0.0.1:6379> lrange list 0 -1

1) "3"

2) "4"

3) "2"

4) "1"

将元素从一个列表转移到另一个列表中   RPOPLPUSH source destination

127.0.0.1:6379> rpoplpush list newlist

"1"

127.0.0.1:6379> lrange newlist 0 -1

1) "1"

127.0.0.1:6379> lrange list 0 -1

1) "3"

2) "4"

3) "2"

数据类型——Set

增加/删除元素  SADD key member [member ...]

127.0.0.1:6379> sadd set a b c

(integer) 3

127.0.0.1:6379> sadd set a

(integer) 0

SREM key member [member ...]

127.0.0.1:6379> srem set c d

(integer) 1

获得集合中的所有元素 SMEMBERS key

127.0.0.1:6379> smembers set

1) "b"

2) "a”

判断元素是否在集合中    SISMEMBER key member

127.0.0.1:6379> sismember set a

(integer) 1

127.0.0.1:6379> sismember set h

(integer) 0

集合的差集运算 A-B(属于A并且不属于B的元素构成的集合)   SDIFF key [key ...]

127.0.0.1:6379> sadd setA 1 2 3

(integer) 3

127.0.0.1:6379> sadd setB 2 3 4

(integer) 3

127.0.0.1:6379> sdiff setA setB

1) "1"

127.0.0.1:6379> sdiff setB setA

1) "4"

集合的交集运算 A ∩ B  属于A且属于B的元素构成的集合。SINTER key [key ...]

127.0.0.1:6379> sinter setA setB

1) "2"

2) "3"

集合的并集运算 A ∪ B   属于A或者属于B的元素构成的集合  SUNION key [key ...]

127.0.0.1:6379> sunion setA setB

1) "1"

2) "2"

3) "3"

4) "4"

获得集合中元素的个数  SCARD key

127.0.0.1:6379> smembers setA

1) "1"

2) "2"

3) "3"

127.0.0.1:6379> scard setA

(integer) 3

从集合中弹出一个元素  SPOP key

注意:由于集合是无序的,所有SPOP命令会从集合中随机选择一个元素弹出

127.0.0.1:6379> spop setA

"1“

数据类型——Sortedset

Sortedset又叫zset

Sortedset是有序集合,可排序的,但是唯一。

Sortedset和set的不同之处,是会给set中的元素添加一个分数,然后通过这个分数进行排序。

向有序集合中加入一个元素和该元素的分数,如果该元素已经存在则会用新的分数替换原有的分数。返回值是新加入到集合中的元素个数,不包含之前已经存在的元素。ZADD key score member [score member ...]

127.0.0.1:6379> zadd scoreboard 80 zhangsan 89 lisi 94 wangwu

(integer) 3

127.0.0.1:6379> zadd scoreboard 97 lisi

(integer) 0

获取元素的分数   ZSCORE key member

127.0.0.1:6379> zscore scoreboard lisi

"97"

移除有序集key中的一个或多个成员,不存在的成员将被忽略。

当key存在但不是有序集类型时,返回一个错误。  ZREM key member [member ...]​​​​​​​

127.0.0.1:6379> zrem scoreboard lisi

(integer) 1

获得排名在某个范围的元素列表:按照元素分数从小到大的顺序返回索引从start到stop之间的所有元素(包含两端的元素)  ZRANGE key start stop [WITHSCORES]

127.0.0.1:6379> zrange scoreboard 0 2

1) "zhangsan"

2) "wangwu"

3) "lisi“

 按照元素分数从大到小的顺序返回索引从start到stop之间的所有元素(包含两端的元素)ZREVRANGE key start stop [WITHSCORES]    

127.0.0.1:6379> zrevrange scoreboard 0 2

1) " lisi "

2) "wangwu"

3) " zhangsan “

如果需要获得元素的分数的可以在命令尾部加上WITHSCORES参数

127.0.0.1:6379> zrange scoreboard 0 1 WITHSCORES

1) "zhangsan"

2) "80"

3) "wangwu"

4) "94"

获取元素的排名   从小到大   ZRANK key member

127.0.0.1:6379> ZRANK scoreboard lisi

(integer) 0

从大到小   ZREVRANK key member

127.0.0.1:6379> ZREVRANK scoreboard zhangsan

(integer) 1

获得指定分数范围的元素   ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]

127.0.0.1:6379> ZRANGEBYSCORE scoreboard 90 97 WITHSCORES

1) "wangwu"

2) "94"

3) "lisi"

4) "97"

127.0.0.1:6379> ZRANGEBYSCORE scoreboard 70 100 limit 1 2

1) "wangwu"

2) "lisi"

增加某个元素的分数  返回值是更改后的分数  ZINCRBY  key increment member

127.0.0.1:6379> ZINCRBY scoreboard 4 lisi

"101“

获得集合中元素的数量  ZCARD key

127.0.0.1:6379> ZCARD scoreboard

(integer) 3

获得指定分数范围内的元素个数  ZCOUNT key min max

127.0.0.1:6379> ZCOUNT scoreboard 80 90

(integer) 1

按照排名范围删除元素  ZREMRANGEBYRANK key start stop

127.0.0.1:6379> ZREMRANGEBYRANK scoreboard 0 1

(integer) 2

127.0.0.1:6379> ZRANGE scoreboard 0 -1

1) "lisi"

按照分数范围删除元素   ZREMRANGEBYSCORE key min max

127.0.0.1:6379> zadd scoreboard 84 zhangsan    

(integer) 1

127.0.0.1:6379> ZREMRANGEBYSCORE scoreboard 80 100

(integer) 1

Keys命令

keys  返回满足给定pattern 的所有key

redis 127.0.0.1:6379> keys mylist*

1) "mylist"

2) "mylist5"

3) "mylist6"

4) "mylist7"

5) "mylist8"

exists   确认一个key 是否存在

示例:从结果来看,数据库中不存在HongWan 这个key,但是age 这个key 是存在的

redis 127.0.0.1:6379> exists HongWan

(integer) 0

redis 127.0.0.1:6379> exists age

(integer) 1

redis 127.0.0.1:6379>

del  删除一个key

redis 127.0.0.1:6379> del age

(integer) 1

redis 127.0.0.1:6379> exists age

(integer) 0

rename   重命名key

redis 127.0.0.1:6379[1]> keys *

1) "age"

redis 127.0.0.1:6379[1]> rename age age_new

OK

redis 127.0.0.1:6379[1]> keys *

1) "age_new"

redis 127.0.0.1:6379[1]>

type  返回值的类型

redis 127.0.0.1:6379> type addr

string

redis 127.0.0.1:6379> type myzset2

zset

redis 127.0.0.1:6379> type mylist

list

redis 127.0.0.1:6379>

设置key的生存时间,Redis在实际使用过程中更多的用作缓存,然而缓存的数据一般都是需要设置生存时间的,即:到期后数据销毁

EXPIRE key seconds                    设置key的生存时间(单位:秒)key在多少秒后会自动删除

TTL key                                         查看key生于的生存时间

PERSIST key                                  清除生存时间

PEXPIRE key milliseconds          生存时间设置单位为:毫秒

192.168.101.3:7002> set test 1                设置test的值为1

OK

192.168.101.3:7002> get test                            获取test的值

"1"

192.168.101.3:7002> EXPIRE test 5        设置test的生存时间为5

(integer) 1

192.168.101.3:7002> TTL test                            查看test的生于生成时间还有1秒删除

(integer) 1

192.168.101.3:7002> TTL test

(integer) -2

192.168.101.3:7002> get test                            获取test的值,已经删除

(nil)

转载于:https://my.oschina.net/px828261/blog/1552174

Redis数据类型及其命令相关推荐

  1. redis 数据类型、命令

    keys 命令  del key  用于在key存在时删除key   dump key  序列化给定key,并返回被序列化的值  exists key  检查给定key是否存在  expire key ...

  2. 解析Redis操作五大数据类型常用命令

    摘要:分享经常用到一些命令和使用场景总结,以及对Redis中五大数据类型如何使用cmd命令行的形式进行操作的方法. 本文分享自华为云社区<Redis操作五大数据类型常用命令解析>,作者:灰 ...

  3. java hmget 最大值,【Redis】基本数据类型及命令操作(超详细)

    一.String 可以直接看每一大节的命令示例部分,敲一遍就大体会了 1.1 概述 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数 ...

  4. redis数据类型插入输出命令

    进入客户机:redis-cli 中文字符不能显示:redis-cli --raw.get Course:1:Cname 一.redis数据类型数据的添加 1.String 添加数据:set Strin ...

  5. redis数据类型_认识Redis与Redis的数据类型

    本文作为Redis的入门教程,旨在让大家对Redis有一个概念性和整体性的认识,并且可以快速上手,为深入Redis打下基础. 文章概要: 1. Redis的介绍 2. Redis与其他数据库的对比 3 ...

  6. Redis 数据类型之(底层解析)

    Redis 数据类型之(底层解析) Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redi ...

  7. Redis 数据类型介绍

    Redis 数据类型介绍 你也许已经知道Redis并不是简单的key-value存储,实际上他是一个数据结构服务器,支持不同类型的值.也就是说,你不必仅仅把字符串当作键所指向的值.下列这些数据类型都可 ...

  8. redis 基本类型和命令(一)

    一.Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). (1) string类型是Redis最基本的数 ...

  9. redis设置密码和启动 redis数据类型

    Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径.Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象. Redis运行在内存中 ...

  10. 【Redis】2. Redis数据类型 String以及key的设置约定

    学习资料 https://www.bilibili.com/video/BV1CJ411m7Gc?p=6 数据存储类型介绍 业务数据的特殊性 作为缓存使用 原始业务功能设计 秒杀 618活动 双十一活 ...

最新文章

  1. Git安装以及操作过程
  2. java writablesheet_jxl加边框,jxl合并单元格,单元格的设置,单元格居中
  3. pv实现前趋图_Excel 数据透视图实现简易交互式数据面板
  4. springcloud20---Config加入eureka
  5. 信息学奥赛一本通 1007:计算(a+b)×c的值 | OpenJudge NOI 1.3 02
  6. mysql使用技巧,使用Mysql的小技巧总结
  7. java输入args不能为空_java程序入口为什么有的空括号在args前面有的?
  8. 4.1 深层神经网络
  9. $.ajax data怎么处理_不用jsp怎么实现前后端交互?给萌新后端的ajax教程(2)
  10. 在R中进行偏相关分析
  11. 小米盒子显示未连接电脑连接服务器,小米盒子不能连接电脑的原因与解决办法...
  12. 电脑共享问题—工作组里看不到其他的WIN10主机
  13. python系统运维工程师_系统运维工程师的工作职责
  14. 微信企业号开发—发送消息
  15. 拼图式拖动滑块的验证——使用selenium+python实现
  16. 脑机接口的深度学习算法
  17. Python-Flask入门,静态文件、页面跳转、错误信息、动态网页模板
  18. 探究 PHP_CodeSniffer 的代码静态分析原理
  19. AndroidStudio电子书的实现
  20. 智能家居控制系统MECOOL KA1智能音响

热门文章

  1. learning scala pattern matching 03
  2. [转载]Linux shell中的竖线(|)——管道符号
  3. Python的lambda, filter, reduce 和 map简介
  4. 基于Windows Azure 搭建基于SharePoint 2010 Intranet、Extranet、Internet (3): 配置负载均衡...
  5. Java中简单Http请求
  6. docker+elasticsearch的安装
  7. 高通camera结构(转)
  8. 洛谷P3690 LCT模板
  9. spring扫描配置文件
  10. 慵懒中长大的人,只会挨生活留下的耳光