231022|redis_demo

安装
https://github.com/tporadowski/redis
https://github.com/redis/redis-py/
解压后要先配置redis.windows.conf文件,里面有本地端口和密码设置
默认host:127.0.0.1 port:6379
打开命令行到redis文件夹下,redis-server.exe redis.windows.conf输入即可(该页面不关闭)
再打开命令行到redis文件夹下运行redis-cli.exe可以输入相关命令
redis在python中的使用
构建server有两个方法 redis.ConnectionPool和redis.Redis
设置数据get/hset/hmset,获取数据hget/hmget/hgetall

python 复制代码
pool = redis.ConnectionPool(host='121.40.96.93', port=6379, db=0, password='123456')
r = redis.Redis(connection_pool=pool)
r = redis.Redis(host='127.0.0.1', port=6379, db=0)
#插入key-value
o = r.set(
        name="name",
        value="我是来及湖南的小明同学",  # value可以是字符串,也可以是任意一个byte字节数组
        ex=60,  # 设置当前加入的key ex秒后过期(删除)
        # px=10000,  # 设置当前加入的key px毫秒后过期;不能和ex同时给定
        nx=False,  # 当设置为True的时候,当却仅当name(key)在redis中不存在的时候,才会插入
        xx=False  # 当设置为True的时候,当却仅当name(key)在redis中存在的时候,才会插入;不能和nx同时给定为True
    )
# get就是获取String类型的key对应的value值
o = r.get(name="name")
# 设置key对应数据过期时间
r.expire(name='user:1001', time=10000)  # 过期秒数
# 让hash结构的value中添加数据
o = r.hset(name="user:1001", key="id", value="1001")
# 建议添加数据的写法(从redis理论上来讲)
o = r.hmset(name="user:1002", mapping={
        "id": "1002",
        "name": "小明1111",
        "age": 17,
        "sex": "男",
        "address": "上海",
        "address2": "北京"
    })
# 一次性获取所有field的value数据 --> hgetall返回结果是一个字典,如果key不存在,那么返回字典为空{}
o = r.hgetall(name='user:1001')
# 针对我们需要的field可以采用(单一field),只要key(name)或者field不存在,返回就是None
o = r.hget(name='user:1001', key='address')
# 针对我们需要的field可以采用(多个field),返回一个list列表,如果field存在对应位置为bytes,如果field不存在,那么对应位置为None
o = r.hmget(name='user:1002', keys=['name', 'age', 'address', 'address2'])

可以用pipeline的方法进行加速

python 复制代码
def t2():
    pool = redis.ConnectionPool(host='121.40.96.93', port=6379, db=0, password='123456', max_connections=100)
    with redis.Redis(connection_pool=pool) as r:
        _t1 = time.time()
        n = 10000
        _pipeline = r.pipeline()
        for i in range(n):
            _pipeline.set(name=f'l:{i}', value=i, ex=220)
        _pipeline.execute()
        print(time.time() - _t1)
相关推荐
sunshine8855 小时前
财务RPA的深水区应用:超越自动化,迈向智能决策支持
数据库
efir OONA5 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
zhangchaoxies6 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
陈陈CHENCHEN6 小时前
【数据库】MySQL 8.0.40 至 8.0.44 RPM 方式升级指南
数据库·mysql
m0_734949797 小时前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤
jvm·数据库·python
T.i.s7 小时前
番外续2-MIT-BIH Arrhythmia Database
数据库
有味道的男人7 小时前
AI 效率翻倍:对接 1688 拍立淘接口,商品全量信息一键抓取
数据库
m0_741173338 小时前
如何处理SQL中的NULL值_使用ISNULL或COALESCE函数
jvm·数据库·python
志栋智能8 小时前
超自动化巡检:解锁运维数据的深层价值
运维·服务器·数据库·自动化
m0_380113848 小时前
补单系统搭建及源码分享
数据库·spring boot·mybatis