了解Redis

一、什么是Redis 概念:

Redis (REmote DIctionary Server) 是用 C 语言开发的一个开源的高性能键值对(key-value)数 据库

特征:

1. 数据间没有必然的关联关系

2. 内部采用单线程机制进行工作

3. 高性能,官方提供测试数据,50个并发执行100000 个请求,读的速度是110000 次/s,写的速度是 81000次/s。

4. 多数据类型支持

  • 字符串类型 string
  • 列表类型 list
  • 散列类型 hash
  • 集合类型 set
  • 有序集合类型 sorted_set

5. 持久化支持。可以进行数据灾难恢复

二、启动 Redis

1.服务器启动

方式1:双击redis-server.exe

方式2:指令redis-server.exe redis.windows.conf

2.客户端连接

三.Redis基本操作

命令行模式工具使用思考

  • 功能性命令
  • 清除屏幕信息
  • 帮助信息查阅
  • 退出指令

信息添加

  • 功能:设置 key,value 数据
  • 命令: set key value

信息查询

  • 功能:根据 key 查询对应的 value,如果不存在,返回空(nil)
  • 命令: get key

清除屏幕信息

  • 功能:清除屏幕中的信息
  • 命令:clear

退出客户端命令行模式

  • 功能:退出客户端
  • 命令:quit exit 按钮

帮助

  • 功能:获取命令帮助文档,获取组中所有命令信息名称
  • 命令: help 命令名称 help @组名

四.Redis 数据类型(5种常用)

1. string  类似于String

2. hash  类似于HashMap

3. list  类似于LinkedList

4. set  类似于HashSet

5. sorted_set  类似于TreeSet

数据存储格式

  • redis 自身是一个 Map,其中所有的数据都是采用 key : value 的形式存储
  • 数据类型指的是存储的数据的类型,也就是 value 部分的类型,key 部分永远都是字符串
  • key的语法: 在一个项目中,key最好使用统一的命名模式
  • key区分大小写 key不要太长,尽量不要超过1024字

4.1 String

存储的数据:

  • 单个数据,最简单的数据存储类型,也是最常用的数据存储类型
  • 存储数据的格式:一个存储空间保存一个数据
  • 存储内容:通常使用字符串,如果字符串以整数的形式展示,可以作为数字操作使用 

添加/修改数据 set key value

获取数据   get key

删除数据   del key

添加/修改多个数据     mset key1 value1 key2 value2 …(m代表Multiple)

获取多个数据  mget key1 key2 …

获取数据字符个数(字符串长度) strlen key

追加信息到原始信息后部(如果原始信息存在就追加,否则新建) append key value

按照范围获取 GETRANGE key 开始下标 结束下标

替换 SETRANGE key 位置  

先get然后在set(做修改) getset key value 

设置数值数据增加指定范围的值 incr key

                                                 incrby key increment

                                                 incrbyfloat key increment

设置数值数据减少指定范围的值 decr key

                                                decrby key increment

设置数据具有指定的生命周期 setex key seconds value

                                        psetex key milliseconds value

设置key的过期时间  EXPIRE key seconds

查看key的剩余时间  ttl key

 4.2 hash

存储的困惑 对象类数据的存储如果具有较频繁的更新需求操作会显得笨重

hash哈希特点

  • 新的存储需求:对一系列存储的数据进行编组,方便管理,典型应用存储对象信息
  • 需要的存储结构:一个存储空间保存多个键值对数据
  • hash类型:底层使用哈希表结构实现数据存储 hash存储结构优化 如果field数量较少,存储结构优化为类数组结构 如果field数量较多,存储结构使用HashMap结构

添加/修改数据 hset key field value

添加,但是有则不添加,无则添加 hsetnx key field value

获取数据 hget key field hgetall key

删除数据 hdel key field1 [field2]

添加/修改多个数据 hmset key field1 value1 field2 value2 …

获取多个数据 hmget key field1 field2 …

获取哈希表中字段的数量 hlen key

获取哈希表中是否存在指定的字段 hexists key field

获取哈希表中所有的字段名或字段值 hkeys key hvals key

设置指定字段的数值数据增加指定范围的值 hincrby key field increment

                                                        hincrbyfloat key field increment hash

类型数据操作的注意事项

1.hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象。如果数据未获取 到,对应的值为(nil)

2.每个 hash 可以存储 2^32^-1个键值对

3.hash类型十分贴近对象的数据存储形式,并且可以灵活添加删除对象属性。但hash设计初衷不是为了 存储大量对象而设计的,切记不可滥用,更不可以将hash作为对象列表使用

4.hgetall 操作可以获取全部属性,如果内部field过多,遍历整体数据效率就很会低,有可能成为数   据访问瓶颈

4.3 List

  • 数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分
  • 需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序
  • list类型:保存多个数据,底层使用双向链表存储结构实现

添加/修改数据 lpush key value1 [value2] ……

                         rpush key value1 [value2] ……

获取数据 lrange key start stop

                lindex key index

                llen key

获取并移除数据 lpop key

                        rpop key

通过下标截取指定的长度,这个list已经被改变了,只剩下截取的元素 ltrim key start end lset

将列表中指定下标的值替换为另外一个值,更新操作

lset key 下标 新数据 # 如果不存在列表我们去更新就会报错

将某个具体的value插入到列中的某个元素的前面或者后面!

LINSERT mylist before "world" "other"

LINSERT mylist after "world" "other"

规定时间内获取并移除数据 blpop key1 [key2] timeout

                brpop key1 [key2] timeout b代表block阻塞

没有则立刻响应为空,但如果是blpop会阻塞,也就是会等,现在没数据不意味着未来没有

blpop list1 30 获取数据,有则返回,没有则等待30秒

list 类型数据操作注意事项

1.list中保存的数据都是string类型的,数据总容量是有限的,最多2^32^-1个元素 (4294967295)

2.list具有索引的概念,但是操作数据时通常以队列的形式进行入队出队操作,或以栈的形式进行入栈出 栈操作

3.获取全部数据操作结束索引设置为-1

4.list可以对数据进行分页操作,通常第一页的信息来自于list,第2页及更多的信息通过数据库的形式加 载 

4.4 Set

  • 新的存储需求:存储大量的数据,在查询方面提供更高的效率
  • 需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询
  • set类型:与hash存储结构完全相同,仅存储键,不存储值(nil),并且值是不允许重复的

添加数据 sadd key member1 [member2]

获取全部数据 smembers key

删除数据 srem key member1 [member2]

获取集合数据总量 scard key

判断集合中是否包含指定数据 sismember key member 

随机获取集合中指定数量的数据 srandmember key [count]

随机获取集合中的某个数据并将该数据移出集合 spop key [count]

求两个集合的交、并、差集

sinter key1 [key2]

sunion key1 [key2]

sdiff key1 [key2]

求两个集合的交、并、差集并存储到指定集合中

sinterstore destination key1 [key2]

sunionstore destination key1 [key2]

sdiffstore destination key1 [key2]

将指定数据从原始集合中移动到目标集合中 smove source destination member

set 类型数据操作的注意事项

1.set 类型不允许数据重复,如果添加的数据在 set 中已经存在,将只保留一份

2.set 虽然与hash的存储结构相同,但是无法启用hash中存储值的空间 

 4.5 sorted_set

  • 新的存储需求:数据排序有利于数据的有效展示,需要提供一种可以根据自身特征进行排序的方式
  • 需要的存储结构:新的存储模型,可以保存可排序的数据
  • sorted_set类型:在set的存储结构基础上添加可排序字段 

添加数据 zadd key score1 member1 [score2 member2]

获取全部数据 zrange key start(开始索引) stop(结束索引) [WITHSCORES]  

#[WITHSCORES]可以除了数据还 显示分值

zrevrange key start stop [WITHSCORES] 反转

删除数据 zrem key member [member ...]

获取集合数据总量 zcard key

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值