我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python模块对Redis数据库的连接与使用讲解

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python模块对Redis数据库的连接与使用讲解

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

​ 1.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()参数讲解:

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

​ 2.port:表示连接的端口。

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

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

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

​ 2.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)内部的操作:

​ 1.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(“键”,“值”) 修改为新值并返回原值。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

​ 3.模糊匹配:


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

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

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

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

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

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

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

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

​ 11.清空数据库的所有数据: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

Python模块对Redis数据库的连接与使用讲解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python模块对Redis数据库的连接与使用讲解

下面看看Python模块对Redis数据库的连接与使用: 1.Python连接Redis数据库方法:import redisres = redis.Redis( host="127.0.0.1",port=6379,db=0,passwo
2022-06-02

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

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

详解Flask数据库的连接与使用

这篇文章主要为大家想想介绍了Python中Flask数据库的连接与使用,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以学习一下
2023-02-24

Java数据库连接PreparedStatement的使用详解

本文介绍了Java数据库连接PreparedStatement的使用详解,分享给大家,具体如下:首先了解Statement和PreparedStatement的区别:由此可见,一般使用PreparedStatement。操作数据库SU(Co
2023-05-31

举例简单讲解Python中的数据存储模块shelve的用法

shelve类似于一个key-value数据库,可以很方便的用来保存Python的内存对象,其内部使用pickle来序列化数据,简单来说,使用者可以将一个列表、字典、或者用户自定义的类实例保存到shelve中,下次需要用的时候直接取出来,就
2022-06-04

ADO.NET中如何使用连接模式访问数据库中的数据

本篇内容介绍了“ADO.NET中如何使用连接模式访问数据库中的数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!ADO.NET框架支持两种模
2023-06-17

连接阿里云RDS云数据库全面理解与使用

阿里云RDS是阿里云提供的一项云数据库服务,它可以让用户轻松地在云上创建、管理、扩展数据库。本文将详细介绍如何连接阿里云RDS云数据库,以及如何进行基本的数据库操作。一、连接阿里云RDS云数据库连接阿里云RDS云数据库的步骤如下:首先,你需要在阿里云控制台中创建一个RDS实例。在创建实例时,你需要选择RDS的类型
连接阿里云RDS云数据库全面理解与使用
2023-11-05

如何使用PHP连接和操作Redis数据库?(PHP连接Redis并进行数据读写的方式是什么?)

本文介绍了如何使用PHP连接和操作Redis数据库。它涵盖了连接、读写字符串、哈希、列表、集合和有序集合等基本操作。还讨论了事务和管道等高级功能。本文提供了详细的代码示例,展示了如何使用PredisClient类与Redis数据库进行交互。通过将PHP与Redis相结合,开发人员可以轻松地创建具有高性能和可扩展性的实际应用程序。
如何使用PHP连接和操作Redis数据库?(PHP连接Redis并进行数据读写的方式是什么?)
2024-04-02

使用Python连接MySQL数据库进行编程的步骤详解

目录1.连接到mysql数据库2.创建表3.插入/更新数据4.查询数据5. 异常处理6.小结PostgreSQL等。本教程将重点介绍使用python连接MySQL数据库进行编程。 MySQL是一种常见的关系型数据库,我们可以使用Python
2023-06-10

使用sqlalchemy-gbasedbt连接GBase8s数据库的步骤详解

这篇文章主要介绍了使用sqlalchemy-gbasedbt连接GBase8s数据库的步骤详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-14

详解springboot 使用c3p0数据库连接池的方法

使用springboot开发时,默认使用内置的tomcat数据库连接池,经常碰到这种情况:运行时间一长,数据库连接中断了。所以使用c3p0连接池吧。引入的maven依赖: c3p0
2023-05-31

阿里云RDS数据库连接用户名的使用与管理

阿里云RDS数据库是阿里云推出的一种云数据库服务,提供了多种数据库类型,包括MySQL、PostgreSQL、Oracle等。本文主要介绍如何使用和管理阿里云RDS数据库的连接用户名。一、如何创建阿里云RDS数据库连接用户名登录阿里云控制台,点击“数据库”服务,选择“RDS”,进入RDS管理页面。点击“创建实例”
阿里云RDS数据库连接用户名的使用与管理
2023-11-07

Python中如何建立与MySQL数据库的安全连接并进行数据交互?(如何使用Python安全地连接到MySQL数据库并执行数据操作?)

本文章详细讲解了如何使用Python安全地连接MySQL数据库并进行数据操作。为了建立安全连接,需配置数据库访问权限、使用SSL加密和密码。Python中的连接配置可通过mysql.connector库实现。数据交互操作包括创建游标、执行查询、获取结果、修改数据和提交更改。安全性最佳实践建议遵循最小权限原则、定期更改密码、使用防火墙、IDS和保持软件更新。
Python中如何建立与MySQL数据库的安全连接并进行数据交互?(如何使用Python安全地连接到MySQL数据库并执行数据操作?)
2024-04-02

怎么解决使用Python连接Oracle数据库报错UnicodeEncodeError问题

这篇文章主要介绍“怎么解决使用Python连接Oracle数据库报错UnicodeEncodeError问题”,在日常操作中,相信很多人在怎么解决使用Python连接Oracle数据库报错UnicodeEncodeError问题问题上存在疑
2023-06-02

Python中的数据对象持久化存储模块pickle的使用示例

Python中可以使用 pickle 模块将对象转化为文件保存在磁盘上,在需要的时候再读取并还原。具体用法如下: pickle是Python库中常用的序列化工具,可以将内存对象以文本或二进制格式导出为字符串,或者写入文档。后续可以从字符或文
2022-06-04

使用sqlalchemy-gbasedbt连接GBase 8s数据库的步骤详解

目录1,确认安装python32,安装GBase 8s数据库连接工具(CSDK)3,安装sqlalchemy-gbasedbt3.1, 在线安装sqlalchemy-gbasedbt4,编写测试Demo,执行测试测试环境:操作系统:Cen
2023-04-01

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录