• https://www.cnblogs.com/szhangli/p/9979600.html

Redis

string类型

  • 字符串类型是 Redis 中最为基础的数据存储类型。
  • 它在 Redis 中是二进制安全的,这便意味着该类型可以接受任何格式的数据。
  • 如JPEG图像数据或Json对象描述信息等。
  • 在Redis中字符串类型的Value最多可以容纳的数据长度是512M。

set:

#设置键值:
set key value #设置键为name值为xiaoming的数据
set name xiaoming

setex:

#设置键值及过期时间,以秒为单位
setex key seconds value #设置键为aa值为aa过期时间为3秒的数据
setex aa 3 aa

mset:

#设置多个键值
mset key1 value1 key2 value2 ... #设置键为a1值为python、键为a2值为java、键为a3值为c
mset a1 python a2 java a3 c++

append:

#追加值
append key value #向键为a1中追加值abc
append a1 abc

get:

#获取:根据键获取值,如果不存在此键则返回nil
get key #获取键name的值
get name

mget:

#获取多个键获取多个值
mget key1 key2 ... #获取键a1、a2、a3的值
mget a1 a2 a3

键命令

key:

#查找键,参数支持正则表达式
keys pattern #查看所有键
keys * #查看名称中包含a的键
keys a*

exists

#判断键是否存在,如果存在返回1,不存在返回0
exists key1 #判断键a1是否存在
exists a1

type:

#查看键对应的value的类型
type key #查看键a1的值类型为redis⽀持的五种类型中的⼀种
type a1

delete:

#删除键及对应的值
del key1 key2... #删除键a1、a2
del a2 a3

expire:

#设置过期时间,以秒为单位
#如果没有指定过期时间则⼀直存在,直到使⽤DEL移除
expire key seconds #设置键a1的过期时间为3秒
expire a1 3

ttl:

#查看有效时间,以秒为单位
ttl key #查看键a1的有效时间
ttl a1

hash类型

  • ash⽤于存储对象,对象的结构为属性、值
  • 值的类型为string

hset:

#设置单个属性
hset key field value #设置键 user的属性name为xiaoming
hset user name xiaoming

hmset:

#设置多个属性
hmset key field1 value1 field2 value2 ... #设置键u2的属性name为itcast、属性age为11
hmset u2 name itcast age 11

hkeys:

#获取指定的键的所有的属性
hkeys key #获取键a1的所有属性
hkeys a1

hget:

#获取多个属性的值
hmget key field1 field2 ... #获取键u2属性name的值
hget u2 name

hmget:

#获取多个属性的值
hmget key field1 field2 ... #获取键u2属性name、age的值
hmget u2 name age

hvals:

#获取所有属性的值
hvals key #获取键u2所有属性的值
hvals u2

hdel

#删除整个hash键及值,使用del命令
#删除属性,属性对应的值会被一起删除
hdel key field1 field2 ... #删除键u2的属性age
hdel u2 age

list类型

  • 列表的元素类型为string
  • 按照插入顺序排序

lpush

#在左侧插入数据
lpush key value1 value2 ... #从键为a1的列表左侧加⼊数据a 、 b 、c
lpush a1 a b c

rpush

#在右侧插入数据
rpush key value1 value2 ... #从键为a1的列表右侧加⼊数据0、1
rpush a1 0 1

linsert

#在指定元素的前或后插入新元素
linsert key before或after 现有元素 新元素 #在键为a1的列表中元素b前加⼊3
linsert a1 before b 3

lrange

#start、stop为元素的下标索引
#索引从左侧开始,第⼀个元素为0
#索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素 #返回列表里指定范围内的元素
lrange key start stop #获取键为a1的列表所有元素
lrange a1 0 -1

lset

#设置指定索引位置的元素值
lset key index value #修改键为a1的列表中下标为1的元素值为z
lset a 1 z

lrem

#列表中前count次出现的值为value的元素移除
#count > 0: 从头往尾移除
#count < 0: 从尾往头移除
#count = 0: 移除所有 #删除指定元素
lrem key count value #向列表a2中加⼊元素a、b、a、b、a、b
lpush a2 a b a b a b #从a2列表右侧开始删除2个b
lrem a2 -2 b

ltrim

#截取保留的元素
ltrim key start stop # 只保留前三个元素(0-2)
ltrim name 0 2

set类型

sadd:

#添加元素
sadd key member1 member2 ... #向键a3的集合中添加元素zhangsan、lisi、wangwu
sadd a3 zhangsan sili wangwu

smembers

#返回所有的元素
smembers key #获取键a3的集合中所有元素
smembers a3

srem

#删除指定元素
srem key #删除键a3的集合中元素wangwu
srem a3 wangwu

zset类型:

  • sorted set,有序集合
  • 元素为string类型
  • 元素具有唯一性,不重复
  • 每一个元素都会关联一个double类型的score,表示权重,通过权重将元素从小到大排序
  • 注:zset类型没有修改操作

zadd

#添加
zadd key score1 member1 score2 member2 ... #向键a4的集合中添加元素lisi、wangwu、zhaoliu、zhangsan,权重分别为4、5、6、3 zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan

zrange

#返回指定范围内的元素(-1表示最后一个元素)
#start、stop为元素的下标索引
#索引从左侧开始,第一个元素为0
#索引可以是负数,表示从尾部开始计数,如-1表示最后一个元素
zrange key start stop #获取键a4的集合中所有元素
zrange a4 0 -1

zrangebyscore

#返回score值在min和max之间的成员
zrangebyscore key min max #获取键a4的集合中权限值在5和6之间的成员
zrangebyscore a4 5 6

zscore

#返回成员member的score值
zscore key member #获取键a4的集合中元素zhangsan的权重
zscore a4 zhangsan

zrem

#删除指定元素
zrem key member1 member2 ... #删除集合a4中元素zhangsan
zrem a4 zhangsan

zremrangebyscore

#删除集合a4中元素zhangsan
zrem a4 zhangsan #删除权重在指定范围的元素
zremrangebyscore key min max #删除集合a4中权限在5、6之间的元素
zremrangebyscore a4 5 6

StrictRedis对象⽅法

引⼊模块

#引入模块
#这个模块中提供了StrictRedis对象,⽤于连接redis服务器,并按照不同类型提供 了不同⽅法,进⾏交互操作 from redis import StrictRedis

通过init创建对象,指定参数host、port与指定的服务器和端⼝连接,host默认为localhost,port默认为6379,db默认为0

sr = StrictRedis(host='localhost',port=6379,db=0)

简写:

sr = StrictRedis()

string-增加

try:
#创建StrictRedis对象,与redis服务器建⽴连接
sr=StrictRedis() #添加键name,值为itheima
result=sr.set('name','xiaoming') #输出响应结果,如果添加成功则返回True,否则返回False
print(result) except Exception as e:
print(e)

string-获取

try:
#创建StrictRedis对象,与redis服务器建⽴连接
sr=StrictRedis() #获取键name的值
result = sr.get('name') #输出键的值,如果键不存在则返回None
print(result) except Exception as e:
print(e)

string-修改

try:
#创建StrictRedis对象,与redis服务器建⽴连接
sr=StrictRedis() #设置键name的值,如果键已经存在则进⾏修改,如果键不存在则进⾏添加
result = sr.set('name','xiaoming') #输出响应结果,如果操作成功则返回True,否则返回False
print(result) except Exception as e:
print(e)

string-删除

try:
#创建StrictRedis对象,与redis服务器建⽴连接
sr=StrictRedis() #设置键name的值,如果键已经存在则进⾏修改,如果键不存在则进⾏添加
result = sr.delete('name') #输出响应结果,如果删除成功则返回受影响的键数,否则则返回0
print(result) except Exception as e:
print(e)

获取键

 try:
#创建StrictRedis对象,与redis服务器建⽴连接
sr=StrictRedis() #获取所有的键
result=sr.keys() #输出响应结果,所有的键构成⼀个列表,如果没有键则返回空列表
print(result) except Exception as e:
print(e)

[转帖]redis操作 + StrictRedis使用的更多相关文章

  1. python 学习笔记 redis操作

    Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...

  2. pyhon之对memcached及redis操作

    Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached ...

  3. python redis操作数据库方法

    Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...

  4. Redis学习---Redis操作之Python连接

    PyCharm下的Redis连接 连接方式: 1. 操作模式 redis-py提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使 ...

  5. Python 使用 Redis 操作

    1.redis简介 redis是一款开源免费的高性能key-value数据库,redis特点: 支持更多的数据类型:字符串(String).列表(List).哈希(Map).数字(Int).集合(Se ...

  6. 使用redis-py的两个类Redis和StrictRedis时遇到的坑

    使用redis-py的两个类Redis和StrictRedis时遇到的坑 前言: 今天产品经理说,有几个队列排序的功能不能用了.对比了下以前的代码查到了一个原因,这个比较的坑,总结起来也是自己没好好看 ...

  7. 缓存系统redis操作、mongdb、memeche

    mongdb :默认数据持久化,存在内存的同时也向硬盘写数据. redis:可配置数据持久化,默认数据在内存中 memeche:only support 内存模式 redis操作 https://ww ...

  8. Atitit.redis操作总结

    Atitit.redis操作总结 1.1. 获取redis所有kv1 1.2. dbsize:返回当前数据库中key的数目 1 1.3. 一起吧所有key列出来1 1.4. Java连接redis   ...

  9. 基于 php-redis 的redis操作

    基于 php-redis 的redis操作 林涛 发表于:2016-5-13 12:12 分类:PHP 标签:php,php-redis,redis 203次 redis的操作很多的,下面的例子都是基 ...

  10. redis操作

    测试环境redis操作 cd /export/servers/redis-2.8.9/src/./redis-cli -n 0 keys keys(pattern):返回满足给定pattern的所有k ...

随机推荐

  1. C++篇:第七章_结构体、共用体和枚举_知识点大全

    C++篇为本人学C++时所做笔记(特别是疑难杂点),全是硬货,虽然看着枯燥但会让你收益颇丰,可用作学习C++的一大利器 七.结构体.共用体和枚举 (一)结构体 C++的结构体中可以有构造函数,例: s ...

  2. 为什么MySQL单表不能超过2000万行?

    摘要:MySQL一张表最多能存多少数据? 本文分享自华为云社区<为什么MySQL单表不能超过2000万行?>,作者: GaussDB 数据库 . 最近看到一篇<我说MySQL每张表最 ...

  3. 4大特性看Huawei Cloud EulerOS为开发者带来平滑迁移体验

    摘要:本期<解密Huawei Cloud EulerOS算力释放技术>主题直播中,华为云DTSE技术布道师陆维迪通过剖析传统OS上云面临的性能,安全,弹性等问题,与开发者们分享Huawei ...

  4. LiteOS内核源码分析:消息队列Queue

    摘要:本文通过分析LiteOS队列模块的源码,掌握队列使用上的差异. 队列(Queue)是一种常用于任务间通信的数据结构.任务能够从队列里面读取消息,当队列中的消息为空时,挂起读取任务:当队列中有新消 ...

  5. 解读分布式调度平台Airflow在华为云MRS中的实践

    摘要:Airflow是一个使用Python语言编写的分布式调度平台,通过DAG(Directed acyclic graph 有向无环图)来管理任务. 本文分享自华为云社区<分布式调度平台Air ...

  6. 从 ByteHouse 网关,看如何进一步提升 OLAP 引擎性能

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群   随着数字化转型的加速,企业面临着海量数据收集.处理和分析挑战.ClickHouse因其分析速度快.高性能的特点 ...

  7. 【活动预告】数据集成引擎BitSail遇上CDC

    BitSail是字节跳动开源数据集成引擎,于2022年10月26日宣布开源,可支持多种异构数据源间的数据同步,并提供离线.实时.全量.增量场景下全域数据集成解决方案.BitSail支撑了字节内部众多的 ...

  8. 对话 BitSail Contributor | 姚泽宇:新生火焰,未来亦可燎原

    2022 年 10 月,字节跳动 BitSail 数据引擎正式开源.同期,社区推出 Contributor 激励计划第一期,目前已有 12 位开发者为 BitSail 社区做出贡献,成为了首批 Bit ...

  9. ElasticSearch 实现分词全文检索 - Java SpringBoot ES 索引操作

    目录 ElasticSearch 实现分词全文检索 - 概述 ElasticSearch 实现分词全文检索 - ES.Kibana.IK安装 ElasticSearch 实现分词全文检索 - Rest ...

  10. PPT 表格设计

    顶级商业图表在哪找 https://www.mckinsey.com.cn/ 麦肯锡 图表 https://www.cbnweek.com 第一财经 https://data.163.com/ DAT ...