文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

聊聊 Python 数据处理全家桶(PgSQL篇)

2024-12-02 23:30

关注

1. 前言

PgSQL,全称为 PostgreSQL,是一款免费开源的关系型数据库

相比最流行的 Mysql 数据库,PgSQL 在可靠性、数据完整性、扩展性方面具有绝对的优势

本篇文章将聊聊如何使用 Python 操作 PgSQL 数据库

2. PgSQL 使用

Python 操作 PgSQL,需要先安装依赖包「 psycopg2 」

  1. # 安装依赖包 
  2. pip3 install psycopg2 

接下来,就可以使用 Python 来操作数据库了

2-1 数据库连接及游标对象

使用 psycopg2 中的「 connect() 」方法连接数据库,创建数据库连接对象及游标对象

  1. import psycopg2 
  2.  
  3. # 获得连接对象 
  4. database:数据库名称 
  5. user:用户名 
  6. password:密码 
  7. # host:数据库ip地址 
  8. # port:端口号,默认为5432 
  9. conn = psycopg2.connect(database="db_name"user="postgres"password="pwd", host="127.0.0.1", port="5432"
  10.  
  11. # 获取游标对象 
  12. cursor = conn.cursor() 

获取游标对象后,就可以执行 SQL,进而操作数据库了

2-2 插入数据

首先,编写插入数据的 SQL 语句及参数( 可选 )

  1. # 构建SQL语句 
  2. # 方式一:直带参数 
  3.  sql = "INSERT INTO student (name,age) \ 
  4.                         VALUES (%s, '%s')" % \ 
  5.           ('xag',23) 
  6.  
  7. # 方式二:参数分离 
  8. sql = """INSERT INTO student (name,age) VALUES (%s, %s)""" 
  9. # 参数 
  10. params = ('xag',23) 

然后,使用游标对象执行 SQL

  1. # 执行sql 
  2. # 注意:params可选,根据上面的参数方式来选择设置 
  3. cursor.execute(sql,[params]) 

接着,使用连接对象提交事务

  1. # 事务提交 
  2. onn.commit() 

最后,释放游标对象及数据库连接对象

  1. # 释放游标对象及数据库连接对象 
  2. cursor.close() 
  3. conn.close() 

2-3 查询数据

游标对象的 fetchone()、fetchmany(size)、fetchall() 这 3个函数即可以实现单条数据查询、多条数据查询、全部数据查询

  1. # 获取一条记录 
  2. one_data = cursor.fetchone() 
  3. print(one_data) 
  4.  
  5. # 获取2条记录 
  6. many_data = cursor.fetchmany(2) 
  7. print(many_data) 
  8.  
  9. # 获取全部数据 
  10. all_data = cursor.fetchall() 
  11. print(all_data) 

需要注意的是,条件查询与上面的插入操作类似,条件语句可以将参数分离出来

  1. # 条件查询 SQL语句 
  2. sql = """SELECT * FROM student where id = %s;""" 
  3.  
  4. # 对应参数,参数结尾以逗号结尾 
  5. params = (1,) 
  6.  
  7. # 执行SQL 
  8. cursor.execute(sql, params) 
  9.  
  10. # 获取所有数据 
  11. datas = cursor.fetchall() 
  12. print(datas) 

2-4 更新数据

更新操作和上面操作一样,唯一不同的是,执行完 SQL 后,需要使用连接对象提交事务,才能将数据真实更新到数据库中

  1. def update_one(conn, cursor): 
  2.     """更新操作""" 
  3.     # 更新语句 
  4.     sql = """update student set name = %s where id = %s  """ 
  5.     params = ('AirPython', 1,) 
  6.  
  7.     # 执行语句 
  8.     cursor.execute(sql, params) 
  9.  
  10.     # 事务提交 
  11.     conn.commit() 
  12.  
  13.     # 关闭数据库连接 
  14.     cursor.close() 
  15.     conn.close() 

2-5 删除数据

删除数据同更新数据操作类似

  1. def delete_one(conn, cursor): 
  2.     """删除操作""" 
  3.     # 语句及参数 
  4.     sql = """delete from  student where id = %s  """ 
  5.     params = (1,) 
  6.  
  7.     # 执行语句 
  8.     cursor.execute(sql, params) 
  9.  
  10.     # 事物提交 
  11.     conn.commit() 
  12.  
  13.     # 关闭数据库连接 
  14.     cursor.close() 
  15.     conn.close() 

3. 最后

通过上面操作,可以发现 Python 操作 PgSQl 与 Mysql 类似,但是在原生 SQL 编写上两者还是有很多差异性

更多关于 PgSQL 的操作可以参考下面链接:

https://www.postgresql.org/docs/14/index.html

 

来源:AirPython内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯