【二、Redis基本命令和五大数据结构】

redis的基础知识和命令

  • redis 是一个单进程(包装epoll函数来对读写事件进行相应)

  • 默认有16个数据库,初始使用的数据库为0号库

  • 默认端口为6379

  • select :切换数据库

  • dbsize:查看当前库的key的个数

  • flushdb:清空当前库

  • flushall:清空所有库

redis的五大数据类型

key键

  • keys *:查看当前所有库的key

 127.0.0.1:6379> keys *
1) "k1"
2) "k2"
  • key xxx*:查看以xxx开头的key

 127.0.0.1:6379> keys k*
1) "k1"
2) "k2"
  • exists key:判断key是否存在;存在返回1;不存在返回0

 127.0.0.1:6379> exists k1 #存在
(integer) 1
127.0.0.1:6379> exists k3 #不存在
(integer) 0
  • move key db:将某个key移动到某个db库,成功返回1失败为0

 127.0.0.1:6379> move k1 1
(integer) 1
127.0.0.1:6379> get k1 #因为k1被移动到1号库所以查询不到
(nil)
127.0.0.1:6379> move k1 1
(integer) 0
  • expire key:设置过期时间(单位是秒)

 127.0.0.1:6379> expire k2 10
(integer) 1
  • persist key:移除过期时间变成永不过期,成功返回1

 127.0.0.1:6379> expire k1 500
(integer) 1
127.0.0.1:6379> ttl k1
(integer) 497
127.0.0.1:6379> persist k1
(integer) 1
127.0.0.1:6379> ttl k
(integer) -1
  • ttl key:查看key的过期状态,-1永不过期,-2已经过期

 127.0.0.1:6379> expire k2 10
(integer) 1
127.0.0.1:6379> ttl k2
(integer) 7
127.0.0.1:6379> ttl k2
(integer) -2
127.0.0.1:6379> ttl k1
(integer) -1
  • del key :删除key

 127.0.0.1:6379> del k1
(integer) 1
  • type key:返回key的类型

 127.0.0.1:6379> type k2
string 127.0.0.1:6379> type k2
string

string

  • set:添加

 127.0.0.1:6379> set k1 v1
OK
  • get:获得

 127.0.0.1:6379> get k1
"v1"
  • del:删除

 127.0.0.1:6379> del k1
(integer) 1
  • append key xxx:往key后面添加xxx

 127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> append k1 123456
(integer) 8
127.0.0.1:6379> get k1
"v1123456"
  • strlen:获取key的长度

127.0.0.1:6379> strlen k1
(integer) 8
  • Incr key:累加 只能是数字相加减不然会报错

  • decr key:累减

 127.0.0.1:6379> lncr k1
(error) ERR unknown command `lncr`, with args beginning with: `k1`,
127.0.0.1:6379> set k2 11
OK
127.0.0.1:6379> INCR k2
(integer) 12
127.0.0.1:6379> decr k2
(integer) 11
  • incrby key n:累加n

  • decrby key n:累减n

127.0.0.1:6379> set k2 11
OK
127.0.0.1:6379> incrby k2 9
(integer) 20
127.0.0.1:6379> decrby k2 10
(integer) 10
  • getrange key 0 -1 获取key的范围值 0 -1 表示全长的值

 127.0.0.1:6379> getrange k1 0 2 #获取下标0-2
"v11"
127.0.0.1:6379> getrange k1 0 -1 #获取总长度
"v1123456"
  • setrange key n xxx 更换key下标以n开始后面的值

127.0.0.1:6379> setrange k1 0 54321
(integer) 8
127.0.0.1:6379> get k1
"54321456"
  • mset :批量添加

  • mget:批量查找

  • msetnx:批量添加很多值 只要存在其中一个key,所有的key都会存不上

127.0.0.1:6379> mset k3 k3 k4 v4
OK
127.0.0.1:6379> mget k3 k4
1) "k3"
2) "v4"
127.0.0.1:6379> msetnx k5 v3 k4 v4
(integer) 0
127.0.0.1:6379> mget k4 k5
1) "44"
2) (nil)
  • getset:先取值在设置值

 127.0.0.1:6379> getset k5 v5
(nil)
127.0.0.1:6379> getset k4 v5
"44"
127.0.0.1:6379> get k4
"v5"

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

  • lpush:反添加

  • rpush:正添加

  • lrange:查看

 127.0.0.1:6379> lpush k1 1 2 3 4 5
(integer) 5
127.0.0.1:6379> LRANGE k1 0 -1
1) "5"
2) "4"
3) "3"
4) "2"
5) "1"
127.0.0.1:6379> rpush k2 1 2 3 4 5
(integer) 5
127.0.0.1:6379> LRANGE k2 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
  • lpop:弹出最上面的key-value

  • rpop:弹出最下面的key-value

  • lindex:按照索引下标获取元素

  • llen:常看长度

 127.0.0.1:6379> LPOP k1
"5"
127.0.0.1:6379> RPOP k1
"1"
127.0.0.1:6379> LRANGE k1 0 -1
1) "4"
2) "3"
3) "2"
127.0.0.1:6379> lindex k1 0
"4"
127.0.0.1:6379> LRANGE k1 0 -1
1) "4"
2) "3"
3) "2"
127.0.0.1:6379> llen k1
(integer) 3
  • lrem key:删除n个value

 127.0.0.1:6379> LRANGE k1 0 -1
1) "3"
2) "2"
3) "1"
127.0.0.1:6379> lrem k1 3 3
(integer) 1
127.0.0.1:6379> LRANGE k1 0 -1
1) "2"
2) "1"
  • ltrim key 开始index 结束index :截取指定范围的值后再给当前key赋值

127.0.0.1:6379> LRANGE k1 0 -1
1) "2"
2) "1"
3) "2"
4) "1"
127.0.0.1:6379> ltrim k1 0 1 #将0-1的值从新赋值给这个key
OK
127.0.0.1:6379> LRANGE k1 0 -1
1) "2"
2) "1"
  • rpoplpush 源列表 目的列表:把元列表的最后的值放在目的列表的最上面

 127.0.0.1:6379> LRANGE k1 0 -1  #k1集合
1) "2"
2) "1"
127.0.0.1:6379> RPOPLPUSH k1 k2 #将k1的第一个值给了k2
"1"
127.0.0.1:6379> LRANGE k2 0 -1 #查看k2的值
1) "1"
2) "1"
3) "2"
127.0.0.1:6379> LRANGE k1 0 -1 #查看k1的值
1) "2"
  • lset key index value : 替换key当前下标的值

 127.0.0.1:6379> LRANGE k1 0 -1
1) "2"
127.0.0.1:6379> lset k1 0 555555555
OK
127.0.0.1:6379> LRANGE k1 0 -1
1) "555555555"
  • linsert key beforre/after 值1 值2 :在具体值得前面或者后面添加value值,不成功返回-1

 127.0.0.1:6379> LRANGE k1 0 -1
1) "555555555"
127.0.0.1:6379> LINSERT k1 before 555555555 111 #在具体值前添加
(integer) 2
127.0.0.1:6379> LINSERT k1 after 555555555 111 #在具体值后添加
(integer) 3
127.0.0.1:6379> LINSERT k1 before 5555 111 #添加失败
(integer) -1
127.0.0.1:6379> LRANGE k1 0 -1
1) "111"
2) "555555555"
3) "111"

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

  • hset:添加

  • hget:查找

  • hdel:删除

127.0.0.1:6379> hset baby id 1
(integer) 1
127.0.0.1:6379> hget baby id
"1"
127.0.0.1:6379> del baby id
(integer) 1
  • hmset :批量添加 一个key的多个属性

  • hmget:批量查找key的多个属性值

  • hkeys:查看所有的key

  • hvals:常看所有的values

  • hgetall:批量查看所有的key-value

 127.0.0.1:6379> hmset baby id 1 name zhangsan age 11
OK
127.0.0.1:6379> hmget baby id name
1) "1"
2) "zhangsan"
127.0.0.1:6379> hkeys baby
1) "id"
2) "name"
3) "age"
127.0.0.1:6379> hvals baby
1) "1"
2) "zhangsan"
3) "11"
127.0.0.1:6379> hgetall baby
1) "id"
2) "1"
3) "name"
4) "zhangsan"
5) "age"
6) "11"
  • hlen:查看有几个属性

  • hexists key: 查看是否存在某个属性值,有返回1,没有返回0

  • hincrby:往某个key的value的后面累加数字 只用于数字 ,其他会报错

  • hsetnx:不存在就赋值 存在就返回0 添加失败

 127.0.0.1:6379> hlen baby
(integer) 3
127.0.0.1:6379> HEXISTS baby id
(integer) 1
127.0.0.1:6379> HEXISTS baby id1
(integer) 0
127.0.0.1:6379> HINCRBY baby id 1111
(integer) 1112
127.0.0.1:6379> HINCRBY baby name 1111
(error) ERR hash value is not an integer
127.0.0.1:6379> hsetnx baby id 1
(integer) 0
127.0.0.1:6379> hsetnx baby id1 1
(integer) 1

set(String 类型的无序不可重复集合。通过哈希表实现的)

  • sadd :添加

  • smembers:查看

  • sismember:查看key里面纯在某个元素

  • scard:获取集合里的元素个数

  • srandmember key n: 随机出n个数

  • srem key value : 删除集合中的元素

 
127.0.0.1:6379> sadd score 1 2 3 4   #添加
(integer) 6
127.0.0.1:6379> smembers score #查看
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> scard score #获取集合里的元素个数
(integer) 4
127.0.0.1:6379> sismember score 2 #查看key里面纯在某个元素
(integer) 1
127.0.0.1:6379> srandmember score 3 #随机出n个数
1) "1"
2) "2"
3) "4"
127.0.0.1:6379> srem score 3 4 #删除集合中的元素
(integer) 2
127.0.0.1:6379> smembers score
1) "1"
2) "2"
  • spop key n: 随机出栈 n个

127.0.0.1:6379> spop b2 3
1) "1"
2) "2"
3) "4"
  • smove key1 key2 member:将key1中的member移动到key2

127.0.0.1:6379> SMOVE b1 b2 3
(integer) 1
127.0.0.1:6379> SMEMBERS b2
1) "1"
2) "3"
  • sdiff:差集

  • sinter:交集

  • sunion:并集

127.0.0.1:6379> sadd b1 1 2 3
(integer) 3
127.0.0.1:6379> sadd b2 1 2 4
(integer) 3
127.0.0.1:6379> sdiff b1 b2 #差集
1) "3"
127.0.0.1:6379> sinter b1 b2 #交集
1) "1"
2) "2"
127.0.0.1:6379> sunion b1 b2 #并集
1) "1"
2) "2"
3) "3"
4) "4"

zset(有序的不可重复列表。每个元素关联一个可重复分数score。通过score进行排序。)

  • zrange:通过索引区间返回有序集合成指定区间内的成员

  • zrangebyscore:通过分数返回有序集合指定区间内的成员

  • zcard:获取有序集合的成员数

  • zcount:计算在有序集合中指定区间分数的成员数

127.0.0.1:6379> zadd zset 1 q 2 w 3 e #向zset添加数据
(integer) 3
127.0.0.1:6379> zrange zset 0 -1 #查询zset全部的数据
1) "q"
2) "w"
3) "e"
127.0.0.1:6379> zrangebyscore zset 1 2 #根据分数范围查找数据
1) "q"
2) "w"
127.0.0.1:6379> zcard zset #获取zset的成员数
(integer) 3
127.0.0.1:6379> zcount zset 1 2 #根据分数范围获取值的个数
(integer) 2
  • zrem:移除有序集合中的一个或多个成员

  • zrevrange :在score范围内按照score从大到小返回数据

127.0.0.1:6379> zrevrange zset 1 2 withscores
1) "w"
2) "2"
3) "4"
4) "1.3"
  • zrevrangebyscore:移除有序集合中给定的分数区间的所有成员

  • ZRANK key :返回有序集合中指定成员的索引

127.0.0.1:6379> zrank zset w #返回w在集合中的索引
(integer) 4
  • ZSCORE key member:返回有序集中成员的分数值

127.0.0.1:6379> zscore zset 4
"1.3"

关于更多的命令指示我们从这个网上去查看http://redisdoc.com/

下一节我们讲一下Redis的持久化之RDB

 关注公众号 果咩z  继续学习redis和其他知识

Redis第二讲【Redis基本命令和五大数据结构】的更多相关文章

  1. Redis第二篇(Redis基本命令)

    -x     从标准输入读取一个参数 such as: echo –en “shaw” |./redis-cli –x setname == set name shaw -r     重复执行一个命令 ...

  2. redis 五大数据结构__常用命令

    linux 下下载redis数据库 apt install redis 如果提示权限不够的话, 直接提权: sudo apt install redis-server linux启用.停止服务 ser ...

  3. Redis五大数据结构

    1.Redis介绍 Redis是REmote DIctionary Server的缩写,作者定位于一个内存KV存储数据库(In-memory key-value Store),让Redis自豪的并不是 ...

  4. redis第一讲【redis的描述,linux和docker下的安装使用】

    Redis(REmote DIctionary Server):是什么 redis(远程字典服务器),是完全开源免费的,高性能的k/v分布式内存数据,热门的Nosql数据库 Redis可以干什么: 内 ...

  5. 第1讲 Redis部署与基本操作

    目录 一.简介 二.安装 1.默认安装位置 2.指定安装位置 3.安装的可执行文件的作用 三.启动与关闭 四.配置文件 五.Redis的数据类型 1. 共计5种类型 2. String(子串类型) 3 ...

  6. 说一下redis中5种数据类型的底层数据结构

      前言: 阅读 redis设计与实现 一书的记录.未完待续... redis我们都知道有5种数据类型,分别是string,list,hash,set,zset,那么你知道它们的底层数据结构实现吗? ...

  7. redis教程(一)-----redis数据类型、基本命令、发布订阅以及持久化

    简介 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发工作由VMwa ...

  8. 第2讲 Redis常用命令与高级应用

    目录 一.redis数据类型 5. sorted sets类型和操作 二.Redis常用命令 1.键值相关命令 2.服务器相关命令 三. redis高级应用 1. 给redis服务器设置密码 2.持久 ...

  9. Linux安装redis PHP安装Redis扩展 and基本命令

    一.安装redis 用超级管理员身份运行: $ mkdir /usr/local/redis #redis安装目录 $ cd /usr/local/src #安装包下载目录 $ wget http:/ ...

随机推荐

  1. php的精度计算问题(bcadd和bcsub)

    一.前言 我们在进行php开发的时候经常会遇到浮点型的问题,特别是涉及金额的部分,常常需要进行加减运算.当小数点的位数比较多的时候,往往容易犯一些很低级的错误.这里记录一下php的精度计算和封装的小d ...

  2. suseoj The wheat of the prime minister

    1202: 2018四川理工学院大学生ACM程序设计:The wheat of the prime minister 时间限制: 1 Sec  内存限制: 128 MB提交: 4  解决: 3[提交] ...

  3. nyoj 19-擅长排列的小明(STL-next_permutation())

    19-擅长排列的小明 内存限制:64MB 时间限制:1000ms Special Judge: No accepted:10 submit:16 题目描述: 小明十分聪明,而且十分擅长排列计算.比如给 ...

  4. nyoj 64-鸡兔同笼 (解二元一次方程)

    64-鸡兔同笼 内存限制:64MB 时间限制:3000ms Special Judge: No accepted:26 submit:58 题目描述: 已知鸡和兔的总数量为n,总腿数为m.输入n和m, ...

  5. 关键路径法(Critical Path Method, CPM)

    1.活动节点描述及计算公式 通过分析项目过程中哪个活动序列进度安排的总时差最少来预测项目工期的网络分析. 产生目的:为了解决,在庞大而复杂的项目中,如何合理而有效地组织人力.物力和财力,使之在有限资源 ...

  6. 2019-11-27:kali 2019-4中文乱码解决方法

    1.更换阿里源 vim /etc/apt/soul,编辑源之后,apt-get updata && apt-get upgrade && apt-get clean , ...

  7. 2019-9-9:渗透测试,docker下载dvwa,使用报错型sql注入dvwa

    docker下载dvwa镜像,报错型注入dvwa,low级 一,安装并配置docker 1,更新源,apt-get update && apt-get upgrade &&am ...

  8. Fragment事务管理源码分析

    转载请标明出处:http://blog.csdn.net/shensky711/article/details/53132952 本文出自: [HansChen的博客] 概述 在Fragment使用中 ...

  9. Jenkins修改默认主目录及数据迁移

    前言 在使用Jenkins做持续集成的初期,未能预估项目量的大小.于是乎,配置都是使用的默认配置,而Jenkins的默认主目录放在了服务器的根目录下. 随着时间的推移,项目量的持续增加,在运维过程中就 ...

  10. 【Android - 进阶】之Animator属性动画

    1.概述 在3.0系统之前,Android给我们提供了逐帧动画Frame Animation和补间动画Tween Animation两种动画: 逐帧动画的原理很简单,就是将一个完整的动画拆分成一张张单 ...