专业IT网络知识平台,分享IT百科知识、生活百科知识解答!

易企推科技
易企推科技

Python中的Psycopg2模块简介

来源:小易整编  作者:小易  发布时间:2024-03-16 08:57
摘要:WeknowthatPythonisaprogramminglanguageusedforaccomplishingvarioustasksinfieldssuchasDataAnalysis,AI...

We know that Python is a programming language used for accomplishing various tasks in fields such as Data Analysis, AI, Machine Learning and so on. And obviously, there are different modules with special functions which help us to do the job.

Python中的Psycopg2模块简介

同样地,Python代码是通过一个称为“Psycopg2模块”的模块与PostgreSQL数据库进行交互的。它是Python的一个流行的PostgreSQL数据库适配器。该模块为我们提供了一组函数和类,帮助我们进行数据库连接、结果处理以及查询执行。

Python中Psycopg2模块的主要特点

数据库连接:Python中的Psycopg2模块带有一个“connect()”函数。该函数帮助建立与PostgreSQL数据库的连接。我们可以将数据库名称、用户名、密码和主机等参数传递给该函数,从而帮助我们连接到我们选择的数据库

查询执行:Psycopg2模块使我们能够针对连接的PsycopgSQL数据库输入SQL查询。"execute()"方法帮助我们执行SQL语句,例如SELECT以访问数据,INSERT、UPDATE和DELETE用于数据操作。

预编译语句:优化SQL查询是Psycopg2模块非常有用的功能。只需预先准备一次SQL查询,然后使用不同的参数多次执行,可以在性能方面带来很大的改进。

Transaction management: Psycopg2 provides us with a function which helps to manage transactions. Initiating a transaction, committing changes within a transaction and to rollback everything, is easier with this module. Transactions ensure the integrity and consistency of data by grouping several database operations into a single unit.

Error Handling: Psycopg2 handles errors and exceptions related to databases, and provides us with detailed error messages and information which helps us to debug issues with the database connection or the query execution.

Result Handling: After executing a query, the Psycopg2 module provides us with methods to fetch the result set, iterate over the rows and access the returned data. We can get inpidual columns or access rows as dictionaries for easier data manipulation.

数据类型转换:Psycopg2会自动将Python对象转换为PostgreSQL支持的相应数据类型。反之亦然。它支持各种内置的PostgreSQL数据类型,如整数、字符串、日期、JSON等

Installation of the Postgre2 Module in Python

Here, we will use the pip command to install the Psycopg2 module. We have to make sure that the latest version of pip is being used. In the terminal, we have to type in the following:

pip install -U pippip install psycopg2-binary
登录后复制

These commands will install the binary version of Pycopg2 which doesn't require any built or runtime prerequisites.

模块的使用方法

The Psycopg2 module has a lot of applications, such as establishing a connection between Python code and a PostgreSQL database. Here is the code that does just that:

Example
import psycopg2DB_NAME = "tkgafrwp"DB_USER = "tkgafrwp"DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi"DB_HOST = "tyke.db.elephantsql"DB_PORT = "5692"try:   conn = psycopg2.connect(database=DB_NAME,                user=DB_USER,                password=DB_PASS,                host=DB_HOST,                port=DB_PORT)   print("Database connected successfully")except:   print("Database not connected successfully")
登录后复制

在这里,我们可以观察到数据库名称、数据库用户、密码、主机和端口已经存储在不同的变量中。然后,为了使代码尽可能健壮,我们使用了try和accept块。在try块内部,我们使用“connect()”函数将Python代码连接到PostgreSQL数据库。该函数使用了我们存储在不同变量中的所有信息

连接到数据库后,我们肯定希望能够对数据库进行一些有用的操作。我们可以使用Python代码来生成SQL查询!下面的代码段将演示这一点:

Example
import psycopg2DB_NAME = "tkgafrwp"DB_USER = "tkgafrwp"DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi"DB_HOST = "tyke.db.elephantsql"DB_PORT = "5692"conn = psycopg2.connect(database=DB_NAME,                user=DB_USER,                password=DB_PASS,                host=DB_HOST,                port=DB_PORT)print("Database connected successfully")cur = conn.cursor()cur.execute("""CREATE TABLE Employee(   ID INT  PRIMARY KEY NOT NULL,   NAME TEXT NOT NULL,   EMAI TEXT NOT NULL)""")connmit()print("Table Created successfully")
登录后复制

Here, we create a cursor using the "cursor()" function and then store it in the cur variable. Then we the format of a multi-line string and we type the SQL query which will go into the database. Then we use the commit() function to apply these changes to the database.

将数据插入到现有表中也是可以的!之前我们创建了表,然后我们将数据输入到表中。下面的代码片段将展示给我们看:

Example
import psycopg2DB_NAME = "tkgafrwp"DB_USER = "tkgafrwp"DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi"DB_HOST = "tyke.db.elephantsql"DB_PORT = "5692"conn = psycopg2.connect(database=DB_NAME,                user=DB_USER,                password=DB_PASS,                host=DB_HOST,                port=DB_PORT)print("Database connected successfully")cur = conn.cursor()cur.execute("""   INSERT INTO Employee (ID, NAME, EMAIL) VALUES   (1, 'Virat Kohli','viratk@gmail'),   (2,' Lionel Messi','leomessi87@gmail') """)connmit()conn.close()
登录后复制

Here, we use the execute() function to execute the SQL statements to insert data into the existing table.

除了将数据插入实际数据库并在服务器上显示,我们还可以在Python终端中显示数据。但是首先,我们需要安装一个名为“mysqlx”的模块。这个模块在使用SQL数据库时也非常有帮助。以下是代码:

Example
from mysqlx import Rowsimport psycopg2DB_NAME = "tkgafrwp"DB_USER = "tkgafrwp"DB_PASS = "iYYtLAXVbid-i6MV3NO1EnU-_9SW2uEi"DB_HOST = "tyke.db.elephantsql"DB_PORT = "5692"conn = psycopg2.connect(database=DB_NAME,                user=DB_USER,                password=DB_PASS,                host=DB_HOST,                port=DB_PORT)print("Database connected successfully")cur = conn.cursor()cur.execute("SELECT * FROM Employee")rows = cur.fetchall()for data in rows:   print("ID :" + str(data[0]))   print("NAME :" + data[1])   print("EMAIL :" + data[2])print('Data fetched successfully and shown on the terminal!')conn.close()
登录后复制

在这里,我们有从“mysqlx”模块获取的行。然后,通过使用for循环,我们遍历表的每一行。通过这种方式,我们获取每一行的所有数据。

以上就是Python中的Psycopg2模块简介的详细内容,更多请关注易企推科技其它相关文章!


本文地址:网络知识频道 https://www.hkm168.com/jiqiao/1148791.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!


网络知识
小编:小易整编
相关文章相关阅读
  • 奇异值分解(SVD)简介及其在图片压缩中的示例

    奇异值分解(SVD)简介及其在图片压缩中的示例

    奇异值分解(SVD)是一种用于矩阵分解的方法。它将一个矩阵分解为三个矩阵的乘积,分别是左奇异向量矩阵、右奇异向量矩阵和奇异值矩阵。SVD在数据降维、信号处理、推荐系统等领域广泛应用。通过SVD,我们可以将高维数据降低到低维空间,从而提取出数...

  • 什么是构造函数?详解JavaScript中的构造函数

    什么是构造函数?详解JavaScript中的构造函数

    作为原型和原型链的基础,先了解清楚构造函数以及它的执行过程才能更好地帮助我们学习原型和原型链的知识。本篇文章带大家详细了解一下javascript中的构造函数,介绍一下怎么利用构造函数创建一个js对象,希望对大家有所帮助!一个普通的函数被用...

  • mysql中的不等于符号是什么

    mysql中的不等于符号是什么

    mysql中的不等于符号有两种:“!=”和“”;它们都可用于判断数字、字符串、表达式是否不相等。对于“!=”和“”,如果两侧操作数不相等,返回值为1,否则返回值为0;如果两侧操作数有一个是null,那么返回值也是null。本教程操作环境:w...

  • 如何取消PPT中的所有动画效果和声音

    如何取消PPT中的所有动画效果和声音

    当我们为ppt添加了动画效果后,有时又会发现需要取消这些动画效果。那么,ppt动画效果怎么全部取消?幸运的是,powerpoint提供了一种简单而高效的方法。下面小编就来为大家讲讲如何去掉ppt的动画效果,让观众更好地关注您想要传达的信息。...

  • Python基础

    Python基础

    前言python,是龟叔在1989年为了打发无聊的圣诞节而编写的一门编程语言,特点是优雅、明确、简单,现今拥有丰富的标准库和第三方库。python适合开发web网站和各种网络服务,系统工具和脚本,作为“胶水”语言把其他语言开发的模块包装起来...

  • Java 中的各种锁有哪些?

    Java 中的各种锁有哪些?

      Java中15种锁的介绍  在读很多并发文章中,会提及各种各样锁如公平锁,乐观锁等等,这篇文章介绍各种锁的分类。介绍的内容如下:  公平锁/非公平锁  可重入锁/不可重入锁  独享锁/共享锁  互斥锁/读写锁  乐观锁...

  • python怎么实现三子棋游戏

    python怎么实现三子棋游戏

    一、基本流程三子棋游戏实现逻辑如下:1、创建初始化3*3棋盘;2、玩家执U子,先进行落子;3、胜负判定【胜、负、和棋】,若胜负未分,则继续如下4、电脑执T子,进行落子;5、胜负判定,若胜负未分,则从步骤2继续执行二、基本步骤1、菜单界面选择...

  • 如何使用PHP中的字符串变量

    如何使用PHP中的字符串变量

    如何使用PHP中的字符串变量在PHP中,字符串变量是一种非常常见的数据类型,用于存储和操作文本数据。在本文中,我们将介绍如何使用PHP中的字符串变量,并提供一些具体的代码示例。字符串变量的声明和赋值在PHP中,要声明一个字符串变量,只需要使...

  • 周排行
  • 月排行
  • 年排行

精彩推荐