文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python模块对Redis数据库的连接与使用方法介绍

2023-06-20 18:12

关注

这篇文章主要讲解了“Python模块对Redis数据库的连接与使用方法介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python模块对Redis数据库的连接与使用方法介绍”吧!

下面看看Python模块对Redis数据库的连接与使用:

Python连接Redis数据库方法:

import redis    res = redis.Redis(    host="127.0.0.1",                port=6379,                db=0,                password="XXXXXX",                decode_responses=True    )    res.set("name","Li")    print(res.get("name"))

redis.Redis()参数讲解:

host:表示连接的主机的iP地址。

port:表示连接的端口。

db:表示使用的数据库的标号。

password:表示连接的数据库的密码。没有不添加该参数即可。

decode_responses:我们从redis数据库中取出的数据默认为字节类型,加上该参数则将取出的数据默认为字符串类型。

Python使用连接池连接Redis数据库:

  import redis        connection = redis.ConnectionPool(        host="127.0.0.1",        port=6379,        password="XXXXXX",        decode_responses=True        )        res = redis.StrictRedis(connection_pool=connection)        res.set("name","666")        print(res.get("name"))

这里使用连接池的作用可以减少中间消耗的时间,当我们这里用完这个连接后将他再次放回连接池中,别的实例使用可以直接使用而不需要重新连接数据库,这样就大幅度的减少了的中间消耗的时间。

连接成功后,下面就是使用Python对redis数据库的操作:

对字符串(String)内部的操作:

res.set()函数:

res.set("name","666",ex=m,px=n,nx=True,xx=True)

这里后四个参数中,ex与px不能共存,nx与xx也不能共存。

ex,px表示数据过期时间,ex是以秒作为单位,px是以毫秒作为单位。当数据过期时键依旧存在,值变为None。

nx与xx表示数据插入数据库的键的状态,nx(新建)为True表示当键不存在时set操作的返回值为True,且新建数据;而xx(修改)为True表示在键存在时set操作返回值为True,且修改数据。否则上述操作返回None。

**故上述操作衍生出的新函数:res.setex(“键”,过期时间(秒),“值”) **

res.setnx(“键”,“值”) 键不存在,返回True并新建。

res.psetex(“键”,过期时间(毫秒),“值”)

res.mset({“键”:“值”,…}) 批量添加键-值数据。

res.mset(“键”,“键”,…) 批量增加键数据。

res.getset(“键”,“值”) 修改为新值并返回原值。

res.strlen(“键”) 返回键对应的值的字节长度。

res.incr(“键”,amount=自增的步长) 不存在则创建,否则自增。

res.decr(“键”,amount=自减的步长) 不存在则创建,否则自减。

res.incrbyfloat(“键”,amount=自增的步长(浮点型))

res.append(“键”,“值”) 将值追加在键对应的值 的 原始字符串后边。

对哈希表(Hash)内部的操作:

单个增加:res.hset(“Hash表名”,“键”,“值”)

批量增加:res.hmset(“Hash表名”,{“键值对”…})

单个取出:res.hget(“Hash表名”,“键”)

多个取出:res.hmget(“Hash表名”,“键”,“键”,…)

只能新建的方法:res.hsetnx(“Hash表名”,“键”,“值”) 当没有时才起新建得作用。

取出hash中的全部键值对:res.hgetall(“Hash表名”)

得到hash中的hash长度(即hash中的键值对个数):res.hlen(“Hash表名”)

得到hash中的所有的键:res.hkeys(“Hash表名”)

得到hash中的所有的值:res.hvals(“Hash表名”)

判断hash中是否存在该成员:res.hexists(“Hash表名”,“键”)

删除hash中的键值对:hdel(“Hash表名”,“键”)

对列表(List)内部的操作:

列表的添加操作: 从左向右添加: res.lpush(“List表名”,“值”,…)

从右向左添加:res.rpush(“List列表”,“值”,…)

这两种方式如果没有该列表就创建,res.l/rpushx()如果没有不创建,且不插入

向固定的索引号位置插入元素:res.linsert(“表名”,“位置”,“将需要插入的元素插入到 ‘该元素' 之前的索引位置(m)”,“被插入的元素(n)”)

例如:res.linsert(“list2”, “before”, “11”, “00”) 往列表中左边第一个出现的“m”元素前插入元素"n"。

修改(指定索引号进行修改):res.lset(“表名”, index, “值”)

删除指定索引的值:res.lrem(“表名”, “值”,矢量删除数(正左负右0全部))

res.l/rpop(“表名”),移除表中的左/右边的第一个数据并将值返回。

取值:res.lindex(“表名”,index)

对集合(Set)内部的操作:

增加数据:res.sadd(“集合名”,“值”)

获取集合的全部成员:res.smembers(“集合名”)

获取集合内的数据数量:res.scard(“集合名”)

以元组格式获取集合的全部成员:res.sscan(“集合名”)

判断值是不是集合的成员:res.sismember(“集合名”,“值”)

删除指定的值:res.srem(“集合名”,“值”)

对集合,列表,字符串,哈希的操作:

删除:res.delete(“键”) 删除该键的数据,不受表类型的约束。

检查名字是否存在:exists(“表名”)

模糊匹配:

KEYS * 匹配数据库中所有 key 。        KEYS h?llo 匹配 hello , hallo 和 hxllo 等。        KEYS hllo 匹配 hllo 和 heeeeello 等。        KEYS h[ae]llo匹配 hello 和 hallo ,但不匹配 hillo                上述为终端命令,下面是Python语法:                res.keys()匹配数据库中所有 key 。        res.keys("h?llo")匹配 hello , hallo 和 hxllo 等。        res.keys("hllo")匹配 hllo 和 heeeeello 等。        res.keys("h[ae]llo")匹配 hello 和 hallo ,但不匹配 hillo

表级重命名:res.rename(“原名”,“新名”)

获取表级的类型:res.type(“表名”)

查看所有元素:res.scan(“表名”)

查看所有元素并生成迭代器:res.scan_iter(“表名”)

获取值:res.get(“键”)

查看当前数据库中包含多少条数据:res.dbsize()

将数据写回磁盘,保存时阻塞:res.save()

清空数据库的所有数据:res.flushdb()

管道(pipeline):

redis默认在执行每次请求都会创建(连接池申请连接)和断开(归还连接池)一次连接操作,如果想要在一次请求中指定多个命令,则可以使用pipline实现一次请求指定多个命令,并且默认情况下一次pipline 是原子性操作。

管道(pipeline)是redis在提供单个请求中缓冲多条服务器命令的基类的子类。它通过减少服务器-客户端之间反复的TCP数据库包,从而大大提高了执行批量命令的功能。

管道操作:

 pipe = res.pipeline() # 创建一个管道        pipe.set('name', 123)        pipe.set('role', 456)        pipe.incr('num')    # 如果num不存在则vaule为1,如果存在,则value自增1。        pipe.execute()      # 无论多少操作最后都需要提交,类似于MySQL的事务。

上述代码可以简化为:

pipe = res.pipeline() # 创建一个管道pipe.set('name', 123).set('role', 456).incr('num').execute()

感谢各位的阅读,以上就是“Python模块对Redis数据库的连接与使用方法介绍”的内容了,经过本文的学习后,相信大家对Python模块对Redis数据库的连接与使用方法介绍这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯