概述
- Redis概念
- Redis使用
- 数据结构
- 命令操作
文章目录
Redis概念
Redis(全称:Remote Dictionary Server 远程字典服务)
Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,官方提供测试数据,50个并发执行100000个请求,读的速度是110000次/s,写的速度是81000次/s !
是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API
总结:Redis是一款高性能的NOSQL系列的非关系型数据库
Redis通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下:
数据结构
- 字符串类型 string
- 哈希类型 hash
- 列表类型 list
- 集合类型 set
- 有序集合类型 sortedset
redis的应用场景
- 缓存(数据查询、短连接、新闻内容、商品内容等等)
- 聊天室的在线好友列表 任务队列(秒杀、抢购、12306等等)
- 应用排行榜
- 网站访问统计
- 数据过期处理(可以精确到毫秒 )
- 分布式集群架构中的session分离
什么是NOSQL?
NoSQL(NoSQL = Not Only SQL),即“不仅仅是SQL”
是一项全新的数据库理念,泛指非关系型的数据库
随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站
特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,
暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展
NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题
NOSQL和关系型数据库比较
优点
- 成本:nosql数据库基本都是开源软件,相比关系型数据库价格便宜(orille)
- 查询速度:nosql数据库将数据存储于缓存之中,关系型数据库将数据存储在硬盘中,自然查询速度远不及nosql数据库
- 存储数据的格式:nosql的存储格式是key,value形式(键值对)、文档形式、图片形式等等,所以可以存储基础类型以及对象或者是集合等各种格式,而数据库则只支持基础类型
NOSQL是基于键值对的,不需要经过SQL层的解析,所以性能非常高。
- 扩展性:关系型数据库有类似join这样的多表查询机制(严格的模式限制)的限制导致扩展很艰难
NOSQL可扩展性同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。
缺点
- 维护的工具和资料有限,因为nosql是属于新的技术,不能和关系型数据库10几年的技术同日而语
- 不提供对sql的支持,MySQL中使用的标准语言是SQL;而NoSQL中缺乏标准的查询语言
- 不提供关系型数据库对事务的处理,sql复杂查询可以用SQL语句方便的在一个表以及多个表之间做非常复杂的数据查询。
以上是自己通过视频的理解,更多可以参考
MySQL数据库与NoSQL数据库的区别
nosql与mysql的区别是什么
总结
两者通常情况下是:使用关系型数据库的同时,在适合使用NoSQL的时候使用NoSQL数据库,让NoSQL数据库对关系型数据库的不足进行弥补
一般会将数据存储在关系型数据库中,在nosql数据库中备份存储关系型数据库的数据
Redis的使用
1.建议中文网下载,国外的网站慢的很
2.解压直接可以使用
3.目录介绍
- redis.windows.conf:配置文件
- redis-cli.exe:redis的客户端
- redis-server.exe:redis服务器端
- redis-benchmark:性能测试工具
- redis-check-aof:修复有问题的AOF文件
- redis-check-dump:修复有问题的dump.rdb文件
- redis-sentinel:redis集群使用
Redis命令
字符串类型 string
- 存储: set key value
127.0.0.1:6379> set username zhangsan
OK
- 获取: get key
127.0.0.1:6379> get username
"zhangsan"
- 删除: del key
127.0.0.1:6379> del age
(integer) 1
哈希类型 hash
- 存储: hset key field value
127.0.0.1:6379> hset myhash username lisi
(integer) 1
- 获取:
hget key field: 获取指定的field对应的值
hgetall key:获取所有的field和value
127.0.0.1:6379> hget myhash username
"lisi"
127.0.0.1:6379> hgetall myhash
1) "username"
2) "lisi"
- 删除: hdel key field
127.0.0.1:6379> hdel myhash username
(integer) 1
列表类型
list:可以添加一个元素到列表的头部(左边)或者尾部(右边)
- 添加:
1. lpush key value: 将元素加入列表左表
2. rpush key value:将元素加入列表右边
127.0.0.1:6379> lpush myList a
(integer) 1
127.0.0.1:6379> lpush myList b
(integer) 2
127.0.0.1:6379> rpush myList c
(integer) 3
- 获取:lrange key start end :范围获取
127.0.0.1:6379> lrange myList 0 -1
1) "b"
2) "a"
3) "c"
- 删除:
lpop key: 删除列表最左边的元素,并将元素返回
rpop key: 删除列表最右边的元素,并将元素返回
集合类型 set : 不允许重复元素
- 存储:sadd key value
127.0.0.1:6379> sadd myset a
(integer) 1
127.0.0.1:6379> sadd myset a
(integer) 0
- 获取:smembers key:获取set集合中所有元素
127.0.0.1:6379> smembers myset
1) "a"
- 删除:srem key value:删除set集合中的某个元素
127.0.0.1:6379> srem myset a
(integer) 1
有序集合类型 sortedset:不允许重复元素,且元素有顺序
每个元素都会关联一个double类型的分数
redis正是通过分数来为集合中的成员进行从小到大的排序。
- 存储:zadd key score value
127.0.0.1:6379> zadd mysort 60 zhangsan
(integer) 1
127.0.0.1:6379> zadd mysort 50 lisi
(integer) 1
127.0.0.1:6379> zadd mysort 80 wangwu
(integer) 1
- 获取:zrange key start end [withscores]
127.0.0.1:6379> zrange mysort 0 -1
1) "lisi"
2) "zhangsan"
3) "wangwu"
127.0.0.1:6379> zrange mysort 0 -1 withscores
1) "zhangsan"
2) "60"
3) "wangwu"
4) "80"
5) "lisi"
6) "500"
- 删除:zrem key value
127.0.0.1:6379> zrem mysort lisi
(integer) 1
通用命令
1. keys * : 查询所有的键
2. type key : 获取键对应的value的类型
3. del key:删除指定的key value