我终于学会了使用python操作postgresql

一 前言

这篇文章不仅适合pgsql,更适合mysql,思路都是一致的,如果读者学会使用psycopg2操作pgsql,那么使用PyMySQL 操作mysql也是很简单;本篇文章涵盖内容广泛,提供的操作选择性很多,比如多种数据插入操作,防止sql注入方式,异常处理,sql语句打印处理,显示行号等操作,一篇文章真的收益匪浅;

二 数据库连接

2.1 安装 psycopg2

#  pip install psycopg2

2.2 连接数据库

每条完整的sql执行步骤如下,读者应谨记;

  1. 建立连接获得 connect 对象
  2. 获得游标对象,一个游标对象可以对数据库进行执行操作,非线程安全,多个应用会在同一个连接种创建多个光标;
  3. 书写sql语句
  4. 调用execute()方法执行sql
  5. 抓取数据(可选操作)
  6. 提交事物
  7. 关闭连接
# -*- coding: utf-8 -*-
import psycopg2
# 获得连接
conn = psycopg2.connect(database="python", user="postgres", password="123456", host="127.0.0.1", port="5432")
# 获得游标对象
cursor = conn.cursor()
# sql语句
sql = "SELECT VERSION()"
# 执行语句
cursor.execute(sql)
# 获取单条数据.
data = cursor.fetchone()
# 打印
print("database version : %s " % data)
# 事物提交
conn.commit()
# 关闭数据库连接
conn.close()

输出结果打印出数据库版本说明连接数据库成功:

database version : PostgreSQL 11.3, compiled by Visual C++ build 1914, 64-bit 

三 创建表

创建学生表主要有字段id 唯一标识,字段 num 代表学号,字段 name 代表学生姓名;详细的建表默认规则转换见附录

# -*- coding: utf-8 -*-
import psycopg2
# 获得连接
conn = psycopg2.connect(database="python", user="postgres", password="123456", host="127.0.0.1", port="5432")
# 获得游标对象,一个游标对象可以对数据库进行执行操作
cursor = conn.cursor()
# sql语句 建表
sql = """CREATE TABLE student (
id serial4 PRIMARY KEY, 
num int4,
name varchar(25));"""
# 执行语句
cursor.execute(sql)
print("student table created successfully")
# 事物提交
conn.commit()
# 关闭数据库连接
conn.close()

四 插入操作

4.1 插入数据姿势一

知识追寻者提供的第一种防止sql注入的插入数据方式(具有占位符的预编译sql),重要程度不言而喻;美中不足是字符串类型必须带上单引号;

# -*- coding: utf-8 -*-
import psycopg2
# 获得连接
conn = psycopg2.connect(database="python", user="postgres", password="123456", host="127.0.0.1", port="5432")
# 获得游标对象,一个游标对象可以对数据库进行执行操作
cursor = conn.cursor()
# sql语句 建表
sql ="INSERT INTO student (num, name) \
                    VALUES (%s, '%s')" % \
                    (100, 'zszxz')
# 执行语句
cursor.execute(sql)
print("successfully")
# 事物提交
conn.commit()
# 关闭数据库连接
conn.close()

4.2 插入数据姿势二(参数分离)

知识追寻者认为下面参数与sql语句分离插入的姿势更简便帅气,也是防止sql注入问题;强烈推荐;

# -*- coding: utf-8 -*-
import psycopg2
# 获得连接
conn = psycopg2.connect(database="python",
  • 8
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Python可以通过psycopg2库来操作PostgreSQL数据库。 首先需要安装psycopg2库,可以使用pip命令进行安装: ``` pip install psycopg2 ``` 安装完成后,可以使用以下代码连接到PostgreSQL数据库: ```python import psycopg2 conn = psycopg2.connect( host="localhost", database="mydatabase", user="myusername", password="mypassword" ) ``` 其中,host为数据库所在的主机名或IP地址,database为要连接的数据库名称,user为连接数据库的用户名,password为连接数据库的密码。 连接成功后,可以使用以下代码执行SQL语句: ```python cur = conn.cursor() cur.execute("SELECT * FROM mytable") rows = cur.fetchall() for row in rows: print(row) ``` 其中,cur为游标对象,execute方法用于执行SQL语句,fetchall方法用于获取所有查询结果。 除此之外,psycopg2库还提供了许多其他的操作数据库的方法,可以根据具体需求进行使用。 ### 回答2: Python是一种开源的高级编程语言,它在与关系型数据库PostgreSQL的交互方面是非常出色的。Python提供了很多数据库接口模块,例如psycopg2模块,它是PostgreSQL数据库的Python驱动、Python db-api和pg8000等。Python内置了SQLite3模块,但是如果要连接PostgreSQL数据库,就需要使用第三方模块。 使用psycopg2模块连接PostgreSQL数据库: 1. 安装psycopg2模块 可以使用pip命令进行安装。 ```python pip install psycopg2 ``` 2. 导入模块,连接数据库 ```python import psycopg2 conn = psycopg2.connect(database='database名称',user='用户名', password='密码', host='主机地址', port='端口号') ``` 3. 执行SQL语句 ```python cur = conn.cursor() cur.execute("SELECT * FROM table_name") rows = cur.fetchall() ``` 4. 关闭连接 ```python cur.close() conn.close() ``` 使用Python操作PostgreSQL数据库,可以实现各种数据库相关的功能。例如,可以向数据库中插入数据,查询数据,更新表格,删除数据等等操作PythonPostgreSQL数据库的结合,极大地提高了数据处理的效率和准确性,其应用场景非常广泛,特别是在数据科学与数据开发的领域中,具有非常重要的作用。 ### 回答3: Python是一种高级编程语言,可以通过其自带的PostgreSQL模块或使用第三方模块,操作PostgreSQL数据库。 首先,需要安装Python的psycopg2模块,可通过以下命令进行安装: ``` pip install psycopg2 ``` 在Python中,可以使用以下步骤连接到PostgreSQL数据库: ``` import psycopg2 # 连接到PostgreSQL数据库 conn = psycopg2.connect(database="mydatabase", user="myusername", password="mypassword", host="localhost", port=5432) # 创建游标 cursor = conn.cursor() # 查询数据示例 cursor.execute("SELECT * FROM mytable;") rows = cursor.fetchall() for row in rows: print(row) # 关闭游标和连接 cursor.close() conn.close() ``` 在上面的代码中,需要将mydatabase、myusername、mypassword、localhost、5432等信息替换为相应的数据库、用户名、密码、主机和端口号。如果需要进行增、删、改等操作,则可以使用execute()方法,如下所示: ``` # 插入数据示例 cursor.execute("INSERT INTO mytable (name, age) VALUES ('John Doe', 30);") conn.commit() ``` 其中,commit()方法用于将更改提交到数据库中。 除了使用psycopg2模块外,还可以使用其他第三方模块,如SQLAlchemy、SQLObject等,它们提供更高层次的封装和更便捷的操作方式。 总之,PythonPostgreSQL的结合为数据科学家和数据分析师提供了极为便捷而强大的工具,可帮助他们更轻松地处理大量数据和数据分析任务。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值