redis的基本操作
- redis是key-value的数据结构,每条数据都是⼀个键值对
- 键的类型是字符串
- 注意:键不能重复
- 值的类型分为五种:
- 字符串string
- 哈希hash
- 列表list
- 集合set
- 有序集合zset
- string类型
- 字符串类型是 Redis 中最为基础的数据存储类型,它在 Redis 中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。
- 设置键值
set key value
- 例1:设置键为name值为itcast的数据
set name itcast
- 设置键值及过期时间,以秒为单位
setex key seconds value
- 例2:设置键为aa值为aa过期时间为3秒的数据
setex aa 3 aa
- 设置多个键值
mset key1 value1 key2 value2 ...
- 例3:设置键为'a1'值为'python'、键为'a2'值为'java'、键为'a3'值为'c'
mset a1 python a2 java a3 c
- 追加值
append key value
- 例4:向键为a1中追加值' haha'
append 'a1' 'haha'
获取
- 获取:根据键获取值,如果不存在此键则返回null
get key
- 例5:获取键'name'的值
get 'name'
- 根据多个键获取多个值
mget key1 key2 ...
- 例6:获取键a1、a2、a3'的值
mget a1 a2 a3
- 查看键对应的value的类型
type key
- 例4:查看键a1的值类型,为redis⽀持的五种类型中的⼀种
type a1
- 删除键及对应的值
del key1 key2 ...
- 例5:删除键a2、a3
del a2 a3
- 设置过期时间,以秒为单位
- 如果没有指定过期时间则⼀直存在,直到使⽤DEL移除
expire key seconds
- 例6:设置键'a1'的过期时间为3秒
expire 'a1' 3
查看有效时间,以秒为单位
ttl key
hash类型
- hash⽤于存储对象,对象的结构为属性、值
- 值的类型为string
- 设置单个属性
增加、修改
hset key field value
- 例1:设置键 user的属性name为itheima
hset user name itheima
MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error.
Redis被配置为保存数据库快照,但它目前不能持久化到硬盘。用来修改集合数据的命令不能用
原因:
- 强制关闭Redis快照导致不能持久化。 解决方案:
- 运行config set stop-writes-on-bgsave-error no 命令后,关闭配置项stop-writes-on-bgsave-error解决该问题。
- 设置多个属性
hmset key field1 value1 field2 value2 ...
- 例2:设置键u2的属性name为itcast、属性age为11
hmset u2 name itcast age 11
获取
- 获取指定键所有的属性
hkeys key
- 例3:获取键u2的所有属性
hkeys u2
- 获取⼀个属性的值
hget key field
- 例4:获取键u2属性'name'的值
hget u2 'name'
- 获取多个属性的值
hmget key field1 field2 ...
- 例5:获取键u2属性'name'、'age的值
hmget u2 name age
- 获取所有属性的值
hvals key
- 例6:获取键'u2'所有属性的值
hvals u2
删除
- 删除整个hash键及值,使⽤del命令
- 删除属性,属性对应的值会被⼀起删除
hdel key field1 field2 ...
- 例7:删除键'u2'的属性'age'
hdel u2 age
list类型
- 列表的元素类型为string
- 按照插⼊顺序排序
- 在左侧插⼊数据
增加
lpush key value1 value2 ...
- 例1:从键为'a1'的列表左侧加⼊数据a 、 b 、c
lpush a1 a b c
- 在右侧插⼊数据
rpush key value1 value2 ...
- 例2:从键为'a1'的列表右侧加⼊数据0 1
rpush a1 0 1
- 在指定元素的前或后插⼊新元素
linsert key before或after 现有元素 新元素
- 例3:在键为'a1'的列表中元素'b'前加⼊'3'
linsert a1 before b 3
获取
- 返回列表⾥指定范围内的元素
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
lrange key start stop
- 例4:获取键为'a1'的列表所有元素
lrange a1 0 -1
设置指定索引位置的元素值
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
lset key index value
- 例5:修改键为'a1'的列表中下标为1的元素值为'z'
lset a 1 z
删除
- 删除指定元素
- 将列表中前count次出现的值为value的元素移除
- count > 0: 从头往尾移除
- count < 0: 从尾往头移除
- count = 0: 移除所有
lrem key count value
- 例6.1:向列表'a2'中加⼊元素'a'、'b'、'a'、'b'、'a'、'b'
lpush a2 a b a b a b
- 例6.2:从'a2'列表右侧开始删除2个'b'
lrem a2 -2 b
- 例6.3:查看列表'py12'的所有元素
lrange a2 0 -1
set类型
- ⽆序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 说明:对于集合没有修改操作
- 添加元素
增加
sadd key member1 member2 ...
- 例1:向键'a3'的集合中添加元素'zhangsan'、'lisi'、'wangwu'
sadd a3 zhangsan sili wangwu
获取
- 返回所有的元素
smembers key
- 例2:获取键'a3'的集合中所有元素
smembers a3
删除
- 删除指定元素
srem key
- 例3:删除键'a3'的集合中元素'wangwu'
srem a3 wangwu
zset类型
- sorted set,有序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
- 说明:没有修改操作
- 添加
增加
zadd key score1 member1 score2 member2 ...
- 例1:向键'a4'的集合中添加元素'lisi'、'wangwu'、'zhaoliu'、'zhangsan',权重分别为4、5、6、3
zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan
获取
- 返回指定范围内的元素
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
zrange key start stop
- 例2:获取键'a4'的集合中所有元素
zrange a4 0 -1
- 返回score值在min和max之间的成员
zrangebyscore key min max
- 例3:获取键'a4'的集合中权限值在5和6之间的成员
zrangebyscore a4 5 6
- 返回成员member的score值
zscore key member
- 例4:获取键'a4'的集合中元素'zhangsan'的权重
zscore a4 zhangsan
删除
- 删除指定元素
zrem key member1 member2 ...
- 例5:删除集合'a4'中元素'zhangsan'
zrem a4 zhangsan
- 删除权重在指定范围的元素
zremrangebyscore key min max
- 例6:删除集合'a4'中权限在5、6之间的元素
zremrangebyscore a4 5 6
redis的基本操作的更多相关文章
- java对redis的基本操作,ZZ
java对redis的基本操作 http://www.cnblogs.com/edisonfeng/p/3571870.html
- python下redis的基本操作:
1. 基本操作: >>> import redis >>> print redis.__file__ /usr/local/lib/python2.7/dist-p ...
- Redis 的基本操作、Key的操作及命名规范
Redis基本操作 查看数据的状态 pong redis 给我们返回 PONG,表示 redis 服务 运行正常 redis 默认用 使用 16 个 库 • Redis 默认使用 16 个库,从 0 ...
- java对redis的基本操作
一.server端安装 1.下载 https://github.com/MSOpenTech/redis 可看到当前可下载版本:redis2.6
- java对redis的基本操作(转)
本文转自:http://www.cnblogs.com/edisonfeng/p/3571870.html 2.主要类 1)功能类 package com.redis; import java.uti ...
- Redis缓存 ava-Jedis操作Redis,基本操作以及 实现对象保存
源代码下载: http://download.csdn.net/detail/jiangtao_st/7623113 1.Maven配置 <dependency> <groupId& ...
- redis - java 基本操作
import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; im ...
- Redis缓存系统(一)Java-Jedis操作Redis,基本操作以及 实现对象保存
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/jiangtao_st/article/details/37699473 源码下载: http://d ...
- java 连接redis 以及基本操作
一.首先下载安装redis 二.项目搭建 1.搭建一个maven 工程 2. 在pom.xml文件的dependencies节点下增加如下内容: <!-- resis --> <de ...
- java对redis的基本操作(初识)
一.server端安装 1.下载 https://github.com/MSOpenTech/redis 可看到当前可下载版本:redis2.6
随机推荐
- 动态规划-爬楼梯问题java实现
最近开始看算法导论,研究了一下动态规划,下面就开始直入主题开始记录近期看的第一个知识点动态规划.提起动态规划就不得不提几个动态规划的金典问题爬楼梯.国王金矿.背包问题.今天就仔细分析一下爬楼梯问题. ...
- 什么是SOA架构
什么是SOA架构 SOA是Service-Oriented Architecture的首字母简称,它是一种支持面向服务的架构样式.从服务.基于服务开发和服务的结果来看,面向服务是一种思考方式.其实SO ...
- vue通过get方法下载java服务器excel模板
vue方法 handleDownTemplateXls(fileName){ if(!fileName || typeof fileName != "string"){ fileN ...
- Interesting丨当我们用蚂蚁的视角看待世界
分享一组很有意思的图片~
- Mac OS删除文件夹和文件的命令
https://www.jianshu.com/p/0376bf0514e3 2017.08.18 17:27* 字数 219 阅读 16709评论 0喜欢 0 rmdir删除空目录,不过一旦目录非空 ...
- ubuntu开启mysql远程连接,并开启3306端口
mysql -u root -p 修改mysql库的user表,将host项,从localhost改为%.%这里表示的是允许任意host访问,如果只允许某一个ip访问,则可改为相应的ip mysql& ...
- HDU 2680 最短路 迪杰斯特拉算法 添加超级源点
Choose the best route Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- Python 使用pillow 操作图像
文档:https://pillow.readthedocs.io/en/stable/index.html 计算机图像基础 颜色和RGBA值 计算机程序通常将图像中的颜色表示为 RGBA 值.RGBA ...
- Apache Shiro安全(权限框架)学习笔记一
1. 授权需要继承 AuthorizingRealm 类, 并实现其 doGetAuthorizationInfo 方法 2. AuthorizingRealm 类继承自 Authenticating ...
- 《SQL 进阶教程》 查找局部不一致的数据
-- 从下面这张商品表里找出价格相等的商品的组合 select * from products p1LEFT JOIN products p2on p1.price = p2.price and p1 ...