linux 下下载redis数据库linux
apt install redis
若是提示权限不够的话, 直接提权:redis
sudo apt install redis-server
linux启用、中止服务sql
service redis start
service redis stop
service redis restart
xshell进入linuxshell
cd .. # 返回根目录 ls # 查看文件 cd etc/
那么到这里,就该进入正题啦。数据库
首先记录下链接、退出、切换数据库的命令数据结构
链接:redis:redis-cli 退出:exit 切换数据库:select n
数据库没有名称,默认有16个,经过0-15来标识,链接redis默认选择第一个数据库(经过select n切换)app
一直说redis有五大数据结构, 都有什么呢。学习
redis是key-value的数据结构,每条数据都是⼀个键值对大数据
键的类型是字符串spa
注意:键不能重复
值的类型分为五种:
String ------> 字符串
Hash ------> 哈希
List ------> 列表
set ------> 集合
Zset ------> 有序集合
如今咱们就开始详细的看下每一个数据类型经常使用的命令有哪些;
string类型
string是redis最基本的类型,一个key对应一个value。
设置给定 key 的值。若是 key 已经存储其余值, SET 就覆写旧值,且无视类型。
设置数据:set key value
设置多组数据:mset key value [key value..]
为多组key设置值,该操做为原子操做,要么一组都设置成功,要么一组都设置失败;
返回一个或多个key的值,若key不存在返回nil,若key存在但不是字符串返回nil
查看数据:get key
将指定的值追加到key末尾,若key不存在,则建立并赋值,返回追加后的字符串长度
追加数据:append key value
返回key的剩余生存时间, -1 表示永久存在, -2表示不存在
ttl key
设置 key的同时,设置过时时间(单位:秒) key 过时后将再也不可用,会被系统自动删除。
set key value ex seconds
set age 18 ex 20
或 setex key seconds value 例: ( setex sex 20 '男' )
移除指定key的生存时间,成功返回1,若key不存在或不存在生存时间时返回0;
persist key
这里追加一个命令:
进入数据库:user db_name;
若是不知道数据库是否存在,记得加if exists
全局key操做
对redis的五个数据类型都适用的命令
rename key newkey 更名
当key和newkey相同或者key不存在时返回一个错误,当newkey已存在时则会覆盖;
keys * # 查看全部的key del key # 删除 返回成功的个数 exists key # 查看key是否存在 返回存在个个数 type key # 查看key类型 expire key seconds #设置过时时间 persist key #移除过时时间
list类型
List类型是一个字符串列表,能够在列表头部或尾部添加/删除数据
在插入数据时,按照插入顺序排序,在列表的头部或者尾部添加元素,
若是该键并不存在,Redis将为该键建立一个。
添加数据:rpush key value [value…] 在尾部添加数据
lpush key value [value…] 在头部添加数据
返回列表中元素的值。index从0开始,当index超出索引时返回null
lindex key index
#查看第2个
查看索引范围内元素的值
查看数据:lrange key start stop
#查看全部值
返回列表的长度
llen key
修改数据:lset key index value
指定索引号进行修改
删除数据:lpop key 删除左边第一个 rpop key 删除右边第一个
Hash类型
是一个键值(key=>value)对集合。是string 类型的 field 和 value 的映射表
user { name:juhao, age:18 }
user -> key(键) name,age ->field(域) juhao,18 ->value(值)
添加数据:
将field-value设置到hash表中,若key不存在会新建hash表再赋值,已存在则会覆盖;
hset key field value
查看域值:
hget key field
批量添加:
hmset key field value field2 value2
查看全部的value:
hvals key
查看全部的field:
hkeys key
# 获取多个 field
hmget key field[field...]
# 获取所有`field` 和 `value
hgetall key
# 查看有几个键值对
hlen key
# 判断hash表中指定域是否存在,返回1,若key或field不存在则返回0;
hexists key field
# 删除
hdel key field
Set类型
元素为string类型
无序集合
元素具备惟一性,不重复
sadd key member [member...] 增长元素
将一个或多个member元素加入到集合key中,若member已存在那么会忽略此元素,
# 返回集合key中元素的个数
scard key
# 获取集合中全部元素
smembers key
# 判断集合存在某个值
判断member在key中是否已存在, 返回0或1
sismember key member
# 删除
移除一个或多个元素,不存在的member会被忽略,返回被移除元素个数
srem key member [member...]
# 随机删除
spop key
移除并返回集合中的一个随机元素,当key不存在时返回NULL
zset类型
相似于Set,不一样的是Sorted中的每一个成员都分配了一个分数(Score)用于对其中的成员进行排序(升序)。
zset的成员是惟一的,但分数(score)却能够重复。
# 添加/修改
zadd key score member[ [score member] ..]
设置, 存在就更新
# 查看
zscore key member
查看score值
# 按索引返回key的成员, withscores表示显示score
zrange key start stop[withscores]
# 显示所有
# 返回集合中 score 在给定区间的元素
zrangebyscore key min max
# 删除
zrem key member [member...]
移除有序集合中的一个或多个元素,若member不存在则忽略;
# 删除集合中索引在给定区间的元素
zremrangebyrank min max
# 删除集合中 score 在给定区间的元素
zremrangebyscore min max
写到这里,redis整理完毕,命令不要死记硬背,用多了天然就记住了。
就像你们写sql ,新建 create table ;插入insert into; 查询 select * from 表 同样。
声明:本文为博主学习感悟总结,水平有限,若是不当,欢迎指正。若是您认为还不错,欢迎转载。转载与引用请注明做者及出处。