Python操作MySQL数据库

一、环境准备

  1. 安装 MySQL 数据库:确保本地或服务器已安装并启动 MySQL 服务。

  2. 安装 Python MySQL 驱动库:常用库有 pymysql(纯 Python 实现,推荐)和 mysql-connector-python(官方驱动)。

二、连接数据库 使用 pymysql.connect() 建立与 MySQL 的连接,需提供数据库地址、用户名、密码、数据库名等参数。

import pymysql

建立数据库连接

try:

connection = pymysql.connect(

host='localhost', # 数据库地址

user='root', # 用户名

password='your_password',# 密码

database='test_db', # 数据库名

port=3306, # 端口(默认3306)

charset='utf8mb4' # 字符集

)

print("数据库连接成功!")

except pymysql.MySQLError as e:

print(f"连接失败:{e}")

三、执行 SQL 操作 通过 cursor() 创建游标对象,使用 execute() 执行 SQL 语句。

1. 创建表

try:

with connection.cursor() as cursor:

编写 SQL 语句

create_table_sql = """

CREATE TABLE IF NOT EXISTS users (

id INT AUTO_INCREMENT PRIMARY KEY,

name VARCHAR(50) NOT NULL,

age INT,

email VARCHAR(100) UNIQUE

)

"""

cursor.execute(create_table_sql)

connection.commit() # 提交事务

print("表创建成功!")

except pymysql.MySQLError as e:

connection.rollback() # 出错回滚

print(f"创建表失败:{e}")

2. 插入数据 • 单条插入:

try:

with connection.cursor() as cursor:

insert_sql = "INSERT INTO users (name, age, email) VALUES (%s, %s, %s)"

cursor.execute(insert_sql, ('张三', 25, 'zhangsan@example.com'))

connection.commit()

print(f"插入成功,影响行数:{cursor.rowcount}")

except pymysql.MySQLError as e:

connection.rollback()

print(f"插入失败:{e}")

• 批量插入: python 运行 try:

with connection.cursor() as cursor:

insert_sql = "INSERT INTO users (name, age, email) VALUES (%s, %s, %s)"

users_data = [

('李四', 30, 'lisi@example.com'),

('王五', 28, 'wangwu@example.com')

]

cursor.executemany(insert_sql, users_data) # 批量执行

connection.commit()

print(f"批量插入成功,影响行数:{cursor.rowcount}")

except pymysql.MySQLError as e:

connection.rollback()

print(f"批量插入失败:{e}")

3. 查询数据 使用 fetchone()(获取单条)、fetchall()(获取所有)或 fetchmany(n)(获取 n 条)获取结果。

try:

with connection.cursor() as cursor:

query_sql = "SELECT * FROM users WHERE age > %s"

cursor.execute(query_sql, (25,))

获取所有结果

results = cursor.fetchall()

print("查询结果:")

for row in results:

print(f"ID: {row0}, 姓名: {row1}, 年龄: {row2}, 邮箱: {row3}")

except pymysql.MySQLError as e:

print(f"查询失败:{e}")

4. 更新数据

try:

with connection.cursor() as cursor:

update_sql = "UPDATE users SET age = %s WHERE name = %s"

cursor.execute(update_sql, (26, '张三'))

connection.commit()

print(f"更新成功,影响行数:{cursor.rowcount}")

except pymysql.MySQLError as e:

connection.rollback()

print(f"更新失败:{e}")

5. 删除数据

try:

with connection.cursor() as cursor:

delete_sql = "DELETE FROM users WHERE name = %s"

cursor.execute(delete_sql, ('王五',))

connection.commit()

print(f"删除成功,影响行数:{cursor.rowcount}")

except pymysql.MySQLError as e:

connection.rollback()

print(f"删除失败:{e}")

四、关闭连接 操作完成后,需关闭游标和数据库连接:

if connection:

connection.close()

print("数据库连接已关闭")

五、注意事项

  1. 事务管理:增删改操作需 commit() 提交,出错时用 rollback() 回滚。

  2. SQL 注入防护:使用 %s 占位符传递参数,避免字符串拼接 SQL。

  3. 资源释放:使用 with 上下文管理器可自动关闭游标,简化代码。

相关推荐
顾林海5 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱7 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils8 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽12 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波12 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码12 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱1 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵1 天前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机