使用 Python 访问数据库的基本方法

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【5月更文挑战第12天】在Python中操作数据库涉及安装数据库驱动(如mysql-connector-python, psycopg2, pymongo)、连接数据库、执行查询/更新、处理结果集及关闭连接。使用ORM(如SQLAlchemy)可简化操作。通过上下文管理器(with语句)能更好地管理资源和错误。注意根据实际需求处理事务、错误和安全性,例如使用SSL连接。

在 Python 中使用数据库的常见方法主要涉及到几个关键步骤:安装和配置数据库驱动、连接到数据库、执行查询和更新操作、处理结果集以及关闭数据库连接。下面是一个大致的流程描述:

安装和配置数据库驱动:
首先,你需要安装一个适合你的数据库的 Python 驱动。对于关系型数据库如 MySQL、PostgreSQL 等,常用的驱动有 mysql-connector-python、psycopg2 等。对于 NoSQL 数据库如 MongoDB,可以使用 pymongo。你可以通过 pip 来安装这些驱动。
bash
pip install mysql-connector-python
pip install psycopg2
pip install pymongo
连接到数据库:
使用相应的驱动,你可以创建一个连接对象来连接到你的数据库。这通常涉及到提供数据库的地址、端口、用户名、密码等信息。
python
import mysql.connector

cnx = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="yourdatabase"
)
执行查询和更新操作:
一旦连接建立,你可以创建一个游标对象来执行 SQL 查询或更新操作。游标允许你执行查询并遍历结果集。
python
cursor = cnx.cursor()

执行查询

query = "SELECT * FROM your_table"
cursor.execute(query)

执行更新

update_query = "UPDATE your_table SET column1 = 'value' WHERE condition"
cursor.execute(update_query)

提交更改(仅对更新操作)

cnx.commit()
处理结果集:
对于查询操作,你可以使用游标的 fetchone()、fetchall() 或 fetchmany(size) 方法来获取结果集中的记录。
python

获取单条记录

record = cursor.fetchone()

获取所有记录

records = cursor.fetchall()

遍历结果集

for (id, name, age) in cursor:
print(f"ID: {id}, Name: {name}, Age: {age}")
关闭游标和数据库连接:
完成所有数据库操作后,记得关闭游标和数据库连接以释放资源。
python
cursor.close()
cnx.close()
使用 ORM(对象关系映射):
虽然直接使用 SQL 可以提供很大的灵活性,但在许多情况下,使用 ORM(如 SQLAlchemy 或 Django ORM)可以简化数据库操作,尤其是当模型变得复杂时。ORM 将数据库表映射为 Python 类,允许你以面向对象的方式操作数据库。
python
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

Base = declarative_base()

class User(Base):
tablename = 'users'
id = Column(Integer, primary_key=True)
name = Column(String)
fullname = Column(String)
password = Column(String)

创建引擎和会话

engine = create_engine('sqlite:///example.db')
Session = sessionmaker(bind=engine)
session = Session()

使用会话执行操作

new_user = User(name='newuser', fullname='New User', password='secret')
session.add(new_user)
session.commit()
使用上下文管理器:
为了简化错误处理和资源管理,可以使用上下文管理器(如 with 语句)来自动关闭游标和连接。这通常在你的数据库驱动或 ORM 中得到支持。
python
with mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="yourdatabase"
) as cnx:
with cnx.cursor() as cursor:
cursor.execute("SELECT * FROM your_table")
for (id, name) in cursor:
print(f"ID: {id}, Name: {name}")
请注意,以上只是使用 Python 访问数据库的基本方法。根据具体的数据库和应用程序需求,你可能还需要处理更复杂的场景,如事务管理、错误处理、连接池等。同时,对于生产环境中的应用程序,确保数据库连接的安全性(如使用 SSL 连接、限制

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7天前
|
机器学习/深度学习 存储 数据挖掘
Python图像处理实用指南:PIL库的多样化应用
本文介绍Python中PIL库在图像处理中的多样化应用,涵盖裁剪、调整大小、旋转、模糊、锐化、亮度和对比度调整、翻转、压缩及添加滤镜等操作。通过具体代码示例,展示如何轻松实现这些功能,帮助读者掌握高效图像处理技术,适用于图片美化、数据分析及机器学习等领域。
49 20
|
2月前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
103 3
|
1月前
|
XML JSON 数据库
Python的标准库
Python的标准库
173 77
|
2月前
|
机器学习/深度学习 算法 数据挖掘
数据分析的 10 个最佳 Python 库
数据分析的 10 个最佳 Python 库
134 4
数据分析的 10 个最佳 Python 库
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
260 15
|
1月前
|
安全
Python-打印99乘法表的两种方法
本文详细介绍了两种实现99乘法表的方法:使用`while`循环和`for`循环。每种方法都包括了步骤解析、代码演示及优缺点分析。文章旨在帮助编程初学者理解和掌握循环结构的应用,内容通俗易懂,适合编程新手阅读。博主表示欢迎读者反馈,共同进步。
|
1月前
|
XML JSON 数据库
Python的标准库
Python的标准库
55 11
|
2月前
|
人工智能 API 开发工具
aisuite:吴恩达发布开源Python库,一个接口调用多个大模型
吴恩达发布的开源Python库aisuite,提供了一个统一的接口来调用多个大型语言模型(LLM)服务。支持包括OpenAI、Anthropic、Azure等在内的11个模型平台,简化了多模型管理和测试的工作,促进了人工智能技术的应用和发展。
156 1
aisuite:吴恩达发布开源Python库,一个接口调用多个大模型
|
1月前
|
数据可视化 Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
通过这些思维导图和分析说明表,您可以更直观地理解和选择适合的数据可视化图表类型,帮助更有效地展示和分析数据。
78 8
|
1月前
|
安全 API 文件存储
Yagmail邮件发送库:如何用Python实现自动化邮件营销?
本文详细介绍了如何使用Yagmail库实现自动化邮件营销。Yagmail是一个简洁强大的Python库,能简化邮件发送流程,支持文本、HTML邮件及附件发送,适用于数字营销场景。文章涵盖了Yagmail的基本使用、高级功能、案例分析及最佳实践,帮助读者轻松上手。
45 4