python pandas 对mysql 一些常见操作

使用 Python 的 pandas 库与 MySQL 数据库进行交互是非常常见的任务。pandas 提供了一个非常方便的方法 read_sql()to_sql(),能够直接读取和写入 MySQL 数据。结合 SQLAlchemypymysql 作为 MySQL 的连接器,可以轻松实现数据的传输。

常见操作:

1. 连接到 MySQL 数据库

首先,你需要使用 SQLAlchemypymysql 来建立与 MySQL 的连接。

bash 复制代码
pip install sqlalchemy pymysql pandas

然后使用下面的代码来建立连接:

python 复制代码
from sqlalchemy import create_engine
import pandas as pd

# 使用 SQLAlchemy 的 create_engine 创建连接
engine = create_engine('mysql+pymysql://username:password@host:port/database_name')

# 或者直接使用 pymysql 连接
import pymysql
connection = pymysql.connect(host='host', user='username', password='password', database='database_name', port=3306)
2. 读取 MySQL 数据到 pandas DataFrame

通过 pandas.read_sql() 方法,可以直接将 MySQL 查询结果加载到 DataFrame 中:

python 复制代码
# 使用 SQLAlchemy engine
query = "SELECT * FROM table_name"
df = pd.read_sql(query, engine)

# 或者使用 pymysql connection
df = pd.read_sql(query, connection)
3. 写入 pandas DataFrame 到 MySQL

pandas 提供了 to_sql() 方法,可以将 DataFrame 中的数据写入 MySQL 表格中。

python 复制代码
# 将 DataFrame 写入 MySQL
df.to_sql('table_name', engine, if_exists='replace', index=False)

if_exists 参数有以下几种选项:

  • 'fail': 如果表已经存在,什么都不做。
  • 'replace': 如果表已经存在,删除旧表并创建新表。
  • 'append': 如果表已存在,将数据追加到现有表中。
4. 执行 SQL 查询操作

如果你只需要执行 SQL 语句而不关心结果(例如插入数据、更新数据),可以使用 engine.execute()connection.cursor()

python 复制代码
# 执行 SQL 语句
with engine.connect() as connection:
    connection.execute("UPDATE table_name SET column_name = value WHERE condition")

或者使用 pymysql 的方式:

python 复制代码
cursor = connection.cursor()
cursor.execute("UPDATE table_name SET column_name = value WHERE condition")
connection.commit()  # 提交更改
5. 从 MySQL 读取数据并进行操作
python 复制代码
# 读取数据到 DataFrame
df = pd.read_sql("SELECT * FROM employees WHERE salary > 50000", engine)

# 进行 pandas 操作,如筛选、聚合等
df_filtered = df[df['age'] > 30]
6. 写入大数据(批量插入)

在处理大量数据时,使用 to_sql() 方法时可以通过设置 chunksize 来分批插入,避免内存溢出。

python 复制代码
# 分批插入数据
df.to_sql('table_name', engine, if_exists='append', index=False, chunksize=1000)
7. 读取大数据(使用分页)

当需要从 MySQL 中读取大量数据时,建议使用分页技术(通过 LIMITOFFSET)来分批读取,避免一次性加载过多数据导致内存问题。

python 复制代码
# 分页查询
offset = 0
batch_size = 1000
query = f"SELECT * FROM table_name LIMIT {batch_size} OFFSET {offset}"
df_batch = pd.read_sql(query, engine)
8. 查询结果按条件筛选
python 复制代码
# 使用 SQL 语句进行筛选
df = pd.read_sql("SELECT * FROM table_name WHERE column_name = 'value'", engine)

# 或者在 pandas 中进行条件筛选
df_filtered = df[df['column_name'] == 'value']

注意事项:

  1. 连接池 :对于高并发应用,建议使用连接池来管理数据库连接。SQLAlchemy 自带连接池,也可以配置。
  2. 事务控制 :对于需要多个 SQL 操作一起提交的场景,可以使用事务控制(BEGINCOMMITROLLBACK)。
  3. 性能 :对于非常大的数据集,可以使用 chunksize 进行分块读取或写入,避免一次性操作过多数据导致内存溢出。

这些基本操作和技巧可以帮助你在 Python 中使用 pandas 和 MySQL 高效地进行数据操作。

你学废了么?

相关推荐
川石课堂软件测试4 小时前
全链路Controller压测负载均衡
android·运维·开发语言·python·mysql·adb·负载均衡
喜欢吃豆4 小时前
微调高级推理大模型(COT)的综合指南:从理论到实践
人工智能·python·语言模型·大模型·微调·强化学习·推理模型
hjbf5 小时前
理解并解决 MySQL 中的 "You can't specify target table for update in FROM clause" 错误
mysql
喜欢吃豆5 小时前
从指令遵循到价值对齐:医疗大语言模型的进阶优化、对齐与工具集成综合技术白皮书
人工智能·python·语言模型·自然语言处理·大模型·强化学习·constitutional
Access开发易登软件5 小时前
Access调用Azure翻译:轻松实现系统多语言切换
后端·python·低代码·flask·vba·access·access开发
yumgpkpm5 小时前
CMP (类Cloudera) CDP7.3(400次编译)在华为鲲鹏Aarch64(ARM)信创环境中的性能测试过程及命令
大数据·hive·hadoop·python·elasticsearch·spark·cloudera
一路向北_Coding5 小时前
MyBatis Generator让你优雅的写SQL
mysql·mybatis
代码小菜鸡6665 小时前
java 常用的一些数据结构
java·数据结构·python
程序猿(雷霆之王)6 小时前
MySQL——复合查询
数据库·mysql
CodeCraft Studio6 小时前
Excel处理控件Aspose.Cells教程:使用 Python 将 HTML 转换为 Excel
python·html·excel·aspose·aspose.cells·html转excel