欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 社会 > 【Python系列】使用 `psycopg2` 连接 PostgreSQL 数据库

【Python系列】使用 `psycopg2` 连接 PostgreSQL 数据库

2025/1/11 5:08:02 来源:https://blog.csdn.net/m0_74824123/article/details/144965526  浏览:    关键词:【Python系列】使用 `psycopg2` 连接 PostgreSQL 数据库

???欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
img

  • 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老
  • 导航
    • 檀越剑指大厂系列:全面总结 java 核心技术,jvm,并发编程 redis,kafka,Spring,微服务等
    • 常用开发工具系列:常用的开发工具,IDEA,Mac,Alfred,Git,typora 等
    • 数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 新空间代码工作室:提供各种软件服务,承接各种毕业设计,毕业论文等
    • 懒人运维系列:总结好用的命令,解放双手不香吗能用一个命令完成绝不用两个操作
    • 数据结构与算法系列:总结数据结构和算法,不同类型针对性训练,提升编程思维,剑指大厂

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。??? 欢迎订阅本专栏

博客目录
    • `psycopg2` 简介
    • 安装 `psycopg2`
    • 连接到 PostgreSQL 数据库
    • 执行 SQL 查询
    • 插入和更新数据
    • 错误处理

在现代软件开发中,数据库是存储和检索数据的核心组件。PostgreSQL 是一个广泛使用的开源对象关系数据库系统,以其强大的功能和灵活性而闻名。Python,作为一种流行的编程语言,提供了多种方式与数据库交互,其中 psycopg2 是连接 PostgreSQL 数据库的流行选择之一。
在这里插入图片描述

psycopg2 简介

psycopg2 是一个 PostgreSQL 数据库的适配器,它允许 Python 程序连接和操作 PostgreSQL 数据库。它提供了许多功能,包括查询执行、事务控制和数据类型转换。psycopg2 是用 C 语言编写的,因此它比纯 Python 库更快,更高效。

安装 psycopg2

在开始之前,确保你的环境中已经安装了 psycopg2。如果你还没有安装,可以通过 Python 的包管理器 pip 来安装。推荐安装 psycopg2-binary,因为它包含了 PostgreSQL 的 C 语言库,这样可以避免额外安装这些库的麻烦。

pip install psycopg2-binary

连接到 PostgreSQL 数据库

连接到 PostgreSQL 数据库需要数据库的配置信息,包括主机名、用户名、端口号、密码和数据库名。以下是一个简单的示例,展示如何使用 psycopg2 来连接到 PostgreSQL 数据库:

import psycopg2# 数据库配置信息
host = "your_host"
user = "your_user"
port = "your_port"  # PostgreSQL 默认端口是 5432
password = "your_password"
dbname = "your_dbname"# 连接数据库
try:conn = psycopg2.connect(host=host,user=user,port=port,password=password,dbname=dbname)print("连接成功")
except psycopg2.Error as e:print(f"连接失败: {e}")

在这段代码中,你需要将 your_hostyour_useryour_portyour_passwordyour_dbname 替换为你的 PostgreSQL 数据库的实际配置信息。

执行 SQL 查询

一旦连接到数据库,你就可以执行 SQL 查询了。psycopg2 提供了几种执行查询的方法,包括 cursor.execute()conn.execute()。以下是如何使用 cursor.execute() 来执行查询的示例:

# 创建 cursor 对象
cursor = conn.cursor()# 执行查询
try:cursor.execute("SELECT * FROM your_table")records = cursor.fetchall()for record in records:print(record)
except psycopg2.Error as e:print(f"查询失败: {e}")
finally:cursor.close()

在这个例子中,我们首先创建了一个 cursor 对象,然后使用 execute() 方法执行了一个 SQL 查询。查询结果通过 fetchall() 方法获取,并打印出来。

插入和更新数据

除了查询数据,psycopg2 也可以用来插入和更新数据库中的数据。以下是如何插入数据的示例:

# 插入数据
try:cursor.execute("INSERT INTO your_table (column1, column2) VALUES (%s, %s)", (value1, value2))conn.commit()  # 提交事务
except psycopg2.Error as e:print(f"插入失败: {e}")conn.rollback()  # 回滚事务
finally:cursor.close()

在这个例子中,我们使用 execute() 方法插入数据,并使用 commit() 方法提交事务。如果插入过程中发生错误,我们使用 rollback() 方法回滚事务,以保持数据库的一致性。

错误处理

在使用 psycopg2 时,错误处理是非常重要的。psycopg2 抛出的异常都是 psycopg2.Error 的实例,你可以通过捕获这些异常来处理错误。如前所述,我们在执行查询和插入数据时都使用了 try...except 块来捕获可能发生的错误。

觉得有用的话点个赞 ???? 呗。
本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!???

???如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!?? ?? ??

???Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!???

img

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com