数据库
首页 > 数据库> > redis非关系型数据库

redis非关系型数据库

作者:互联网

redis是一种nosql数据库,他的数据是保存在内存中,同时redis可以定时把内存数据同步到磁盘,即可以将数据持久化,并且他比memcached支持更多的数据结构(string,list列表[队列和栈],set[集合],sorted set[有序集合],hash(hash表))

默认端口号:6379

使用场景(数据不是很重要,且数据经常变化)

redis与memcached的比较
在这里插入图片描述

搭建扩展源

#yum -y install epel-release

下载redis

#yum -y install redis

连接redis

#redis-cli -p 6379 -h 127.0.0.1

set

添加值

set name chen

取出值

get name

查看所有值(变量名)
keys *

再次set name 666 则将之前的chen覆盖

删除变量名
del name

设置过期时间 ex
set name chen ex 10   #十秒过期

查看过期时间ttl
set name chen ex 19
ttl name

列表操作
在列表左边添加元素

lpush chen zhao qiu    #将值zhao  qiu 插入表chen的表头中,
lrange chen 0 -1          #查看lrange有哪些值valus
rpop chen                    #移除chen中的头元素

在列表右边添加元素

rpush chen 666            #将值666  插入表chen的表尾,
rpop chen                     #移除chen中的尾元素

集合:(不可重复性)
创建集合组及成员

#sadd qiu java dajiahao dabaojian

查看集合成员

#smembers qiu

移除集合成员

#srem qiu dabaojian

查看两个集合的交集 (intersection)

#sinter qiu qiu2

并集为(union)

#sunion qiu qiu2

哈希操作:
添加值

hset zhao age 18

查看值

hget zhao age

在这里插入图片描述

删除值

hdel zhao age

查看所有值

hgetall zhao

列出所有的key键

hkeys zhao

在这里插入图片描述

获取键值对

hlen zhao

事物操作:Redis事务可以一次执行多个命令,事务具有以下特征:
隔离操作:事务中的所有命令都会序列化、按顺序地执行,不会被其他命令打扰。
原子操作:事务中的命令要么全部被执行,要么全部都不执行。
开启一个事务

multi 
以后执行的所有命令,都在这个事务中执行的。

执行事务:

exec
会将在multi和exec中的操作一并提交。

取消事务:

discard
会将multi后的所有命令取消。

监视一个或者多个key:

watch key...
监视一个(或多个)key,如果在事务执行之前这个(或这些) key被其他命令所改动,那么事务将被打断。

取消所有key的监视:

unwatch

.发布/订阅操作:
给某个频道发布消息:

publish channel message

订阅某个频道的消息:

subscribe channel

持久化
redis提供了两种数据备份方式,一种是RDB,另外一种是AOF,以下将详细介绍这两种备份策略:

在这里插入图片描述

标签:关系,set,name,数据库,redis,qiu,zhao,chen
来源: https://blog.csdn.net/weixin_44267608/article/details/88357817