Python - 操作 PostgreSQL 数据库的基本方法与代码
wptr33 2025-01-06 15:47 27 浏览
本文记录在Python编程中操作PostgreSQL数据库的基本方法与实现代码,包括连接数据库、创建数据表、插入/更新/删除数据表中的记录、函数调用、存储过程调用及事务处理等。
获取数据库
首先把连接数据的信息写入 database.ini 文本文件中,内容如下:
[postgresql]
host=localhost
database=dbname
user=postgres
password=123456
然后定义一个读取database.ini文件的函数,代码如下:
import psycopg2
from configparser import ConfigParser
def load_config(filename='database.ini', section='postgresql'):
parser = ConfigParser()
parser.read(filename)
# 获取数据库的设置参数
config = {}
if parser.has_section(section):
params = parser.items(section)
for param in params:
config[param[0]] = param[1]
else:
raise Exception(' 在 {0} 文件中没有发现参数 {1}'.format(filename,section))
return config
if __name__ == '__main__':
config = load_config()
print(config)
以上代码运行结果如下:
{'host': 'localhost', 'database': 'dbname', 'user': 'postgres', 'password': '123456'}
建立数据库连接
import psycopg2
from config import load_config
def connect(config):
try:
with psycopg2.connect(**config) as conn:
print('已连接到 PostgreSQL server.')
return conn
except (Exception. psycopg2.DatabaseError ) as error:
print(error)
if __name__ == '__main__':
config = load_config()
connect(config)
创建数据表
import psycopg2
from config import load_config
def create_tables():
commands = (
"""
CREATE TABLE vendors (
vendor_id SERIAL PRIMARY KEY,
vendor_name VARCHAR(255) NOT NULL
)
""",
""" CREATE TABLE parts (
part_id SERIAL PRIMARY KEY,
part_name VARCHAR(255) NOT NULL
)
""",
"""
CREATE TABLE part_drawings (
part_id INTEGER PRIMARY KEY,
file_extension VARCHAR(5) NOT NULL,
drawing_data BYTEA NOT NULL,
FOREIGN KEY (part_id)
REFERENCES parts (part_id)
ON UPDATE CASCADE ON DELETE CASCADE
)
""",
"""
CREATE TABLE vendor_parts (
vendor_id INTEGER NOT NULL,
part_id INTEGER NOT NULL,
PRIMARY KEY (vendor_id , part_id),
FOREIGN KEY (vendor_id)
REFERENCES vendors (vendor_id)
ON UPDATE CASCADE ON DELETE CASCADE,
FOREIGN KEY (part_id)
REFERENCES parts (part_id)
ON UPDATE CASCADE ON DELETE CASCADE
)
""")
try:
config = load_config()
with psycopg2.connect(**config) as conn:
with conn.cursor() as cur:
# execute the CREATE TABLE statement
for command in commands:
cur.execute(command)
except (Exception, psycopg2.DatabaseError) as error:
print(error)
if __name__ == '__main__':
create_tables()
插入1条或多条记录到数据表
def insert_vendor(vendor_name):
sql = """INSERT INTO vendors(vendor_name)
VALUES(%s) RETURNING vendor_id;"""
vendor_id = None
config = load_config()
try:
with psycopg2.connect(**config) as conn:
with conn.cursor() as cur:
# execute the INSERT statement
cur.execute(sql, (vendor_name,))
# get the generated id back
rows = cur.fetchone()
if rows:
vendor_id = rows[0]
conn.commit()
except (Exception, psycopg2.DatabaseError) as error:
print(error)
finally:
return vendor_id
def insert_many_vendors(vendor_list):
sql = "INSERT INTO vendors(vendor_name) VALUES(%s) RETURNING *"
config = load_config()
try:
with psycopg2.connect(**config) as conn:
with conn.cursor() as cur:
# execute the INSERT statement
cur.executemany(sql, vendor_list)
# commit the changes to the database
conn.commit()
except (Exception, psycopg2.DatabaseError) as error:
print(error)
if __name__ == '__main__':
insert_vendor("拓邦电子")
insert_many_vendors([
('中兴通讯',),
('洪都航空',),
('招商银行',),
('九阳股份',)
])
函数调用
# import psycopg2
# from config import load_config
def get_parts(vendor_id):
parts = []
# read database configuration
params = load_config()
try:
# 连接数据库
with psycopg2.connect(**params) as conn:
with conn.cursor() as cur:
# create a cursor object for execution
cur = conn.cursor()
cur.callproc('get_parts_by_vendor', (vendor_id,))
# 处理要插入的数据
row = cur.fetchone()
while row is not None:
parts.append(row)
row = cur.fetchone()
except (Exception, psycopg2.DatabaseError) as error:
print(error)
finally:
return parts
if __name__ == '__main__':
parts = get_parts(1)
print(parts)
更新数据表中的记录
# import psycopg2
# from config import load_config
def update_vendor(vendor_id, vendor_name):
updated_row_count = 0
sql = """ UPDATE vendors
SET vendor_name = %s
WHERE vendor_id = %s"""
config = load_config()
try:
with psycopg2.connect(**config) as conn:
with conn.cursor() as cur:
# 执行 UPDATE 语句
cur.execute(sql, (vendor_name, vendor_id))
updated_row_count = cur.rowcount
# 提交更新数据到数据库
conn.commit()
except (Exception, psycopg2.DatabaseError) as error:
print(error)
finally:
return updated_row_count
if __name__ == '__main__':
update_vendor(1, "拓邦股份")
调用存储过程
# import psycopg2
# from config import load_config
# 增加一个新的零部件
def add_part(part_name, vendor_name):
# 读取数据库参数
params = load_config()
try:
# 连接数据库
with psycopg2.connect(**params) as conn:
with conn.cursor() as cur:
# 调用一个存储过过程
cur.execute('CALL add_new_part(%s,%s)', (part_name, vendor_name))
# 提交数据变化到数据库
conn.commit()
except (Exception, psycopg2.DatabaseError) as error:
print(error)
if __name__ == '__main__':
add_part('液晶板', '京东方')
事务处理
# import psycopg2
# from config import load_config
def add_part(part_name, vendor_list):
# 给part数据表插入一条新记录
insert_part = "INSERT INTO parts(part_name) VALUES(%s) RETURNING part_id;"
# 给 vendor_parts 数据表插入一条新记录
assign_vendor = "INSERT INTO vendor_parts(vendor_id,part_id) VALUES(%s,%s)"
conn = None
config = load_config()
try:
with psycopg2.connect(**config) as conn:
with conn.cursor() as cur:
# 增加一个新的零部件
cur.execute(insert_part, (part_name,))
# 获取该零部件的 id
row = cur.fetchone()
if row:
part_id = row[0]
else:
raise Exception('没有该零件的 id')
# 零部件与供应商对应,插入新记录
for vendor_id in vendor_list:
cur.execute(assign_vendor, (vendor_id, part_id))
# 提交事务
conn.commit()
except (Exception, psycopg2.DatabaseError) as error:
if conn:
conn.rollback()
print(error)
if __name__ == '__main__':
# add_part('扬声器', (3, 4))
# add_part('示波器', (5, 6))
# add_part('天线', (6, 7))
# add_part('按钮', (1, 5))
# add_part('调制解调就', (1, 5))
add_part('功率放大器', (99,))
(本文完)
- 上一篇:python执行.sql语法和文件
- 下一篇:sql并集、交集、差集
相关推荐
- oracle数据导入导出_oracle数据导入导出工具
-
关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...
- 继续学习Python中的while true/break语句
-
上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...
- python continue和break的区别_python中break语句和continue语句的区别
-
python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...
- 简单学Python——关键字6——break和continue
-
Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
-
用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...
- Python 中 break 和 continue 傻傻分不清
-
大家好啊,我是大田。...
- python中的流程控制语句:continue、break 和 return使用方法
-
Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...
- L017:continue和break - 教程文案
-
continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...
- 作为前端开发者,你都经历过怎样的面试?
-
已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...
- 面试被问 const 是否不可变?这样回答才显功底
-
作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...
- 2023金九银十必看前端面试题!2w字精品!
-
导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...
- 前端面试总结_前端面试题整理
-
记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...
- 由浅入深,66条JavaScript面试知识点(七)
-
作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...
- 2024前端面试真题之—VUE篇_前端面试题vue2020及答案
-
添加图片注释,不超过140字(可选)...
- 今年最常见的前端面试题,你会做几道?
-
在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...
- 一周热门
- 最近发表
-
- oracle数据导入导出_oracle数据导入导出工具
- 继续学习Python中的while true/break语句
- python continue和break的区别_python中break语句和continue语句的区别
- 简单学Python——关键字6——break和continue
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
- Python 中 break 和 continue 傻傻分不清
- python中的流程控制语句:continue、break 和 return使用方法
- L017:continue和break - 教程文案
- 作为前端开发者,你都经历过怎样的面试?
- 面试被问 const 是否不可变?这样回答才显功底
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)
