Python使用PyMySql增删改查Mysql数据库

PyMysql简介

PyMysql是Python中用于连接MySQL数据库的一个第三方库,它实现了MySQL客户端/服务器协议,使得Python程序能够与MySQL服务器进行交互。由于Python
2的mysql-python(又称mysqldb)模块在Python 3上支持不够完善,因此pymysql成为了在Python
3.x环境中一个流行的替代方案。

PyMysql的主要特点和功能:

  • 兼容性:pymysql与Python 3完全兼容,并且可以在Python
    2.7及更高版本上运行,为跨Python版本的应用提供统一的MySQL数据库操作接口。
  • API设计:提供了类似DB-API 2.0规范的接口,使得开发者可以使用熟悉的执行SQL语句、获取结果集等方法。
  • 安全连接:支持安全的SSL加密连接到MySQL服务器。
  • 事务处理:通过commit()和rollback()方法支持事务控制。
  • 参数化查询:允许使用占位符(%s)进行参数化SQL查询,有效防止SQL注入攻击。
  • 多结果集:对于支持多结果集的MySQL命令,如存储过程,pymysql也能够正确处理。

基本用法步骤:

  1. 安装pymysql(通常使用pip install pymysql)
  2. 创建数据库连接
  3. 创建游标对象并执行SQL语句
  4. 处理查询结果
  5. 提交或回滚事务
  6. 关闭游标和数据库连接

以下使用PyMysql增删改查Mysql数据库

创建数据库

CREATE TABLE `users` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(50) NOT NULL,
  `email` varchar(100) NOT NULL,
  `password` varchar(100) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

连接MySql数据库

import pymysql

# 连接MySQL数据库
db = pymysql.connect("localhost", "your_username", "your_password", "your_database")

# 创建一个游标对象cursor
cursor = db.cursor()

查询数据(SELECT)

import pymysql

# 连接MySQL数据库
db = pymysql.connect("localhost", "your_username", "your_password", "your_database")
# 创建一个游标对象cursor
cursor = db.cursor()
try:
    sql = "SELECT * FROM users WHERE username = %s"
    val = ("test_user",)
    cursor.execute(sql, val)
    results = cursor.fetchall()
    for row in results:
        print(f"ID: {row[0]}, Username: {row[1]}, Email: {row[2]}, Password: {row[3]}")
except Exception as e:
    print(f"查询数据失败: {e}")

插入数据(INSERT)

import pymysql

# 连接MySQL数据库
db = pymysql.connect("localhost", "your_username", "your_password", "your_database")

# 创建一个游标对象cursor
cursor = db.cursor()
# 插入数据(INSERT)
try:
    sql = "INSERT INTO users (username, email, password) VALUES (%s, %s, %s)"
    val = ("test_user", "test@example.com", "test_password")
    cursor.execute(sql, val)
    db.commit()
    print("插入数据成功")
except Exception as e:
    db.rollback()  # 发生错误时回滚
    print(f"插入数据失败: {e}")

更新数据(UPDATE)

import pymysql

# 连接MySQL数据库
db = pymysql.connect("localhost", "your_username", "your_password", "your_database")

# 创建一个游标对象cursor
cursor = db.cursor()
try:
    sql = "UPDATE users SET email = %s WHERE username = %s"
    val = ("new_email@example.com", "test_user")
    cursor.execute(sql, val)
    db.commit()
    print("更新数据成功")
except Exception as e:
    db.rollback()
    print(f"更新数据失败: {e}")

删除数据(DELETE)

import pymysql

# 连接MySQL数据库
db = pymysql.connect("localhost", "your_username", "your_password", "your_database")

# 创建一个游标对象cursor
cursor = db.cursor()
try:
    sql = "DELETE FROM users WHERE username = %s"
    val = ("test_user",)
    cursor.execute(sql, val)
    db.commit()
    print("删除数据成功")
except Exception as e:
    db.rollback()
    print(f"删除数据失败: {e}")

关闭连接

cursor.close()
db.close()

请确保将上述代码中的"your_username", “your_password”, "your_database"替换为你的实际数据库用户名、密码和数据库名。

  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以为您提供一些关于使用pymysql库进行MySQL数据库增删改查的基本操作。以下是一个简单的示例代码: ```python import pymysql # 连接到数据库 conn = pymysql.connect(host='localhost', port=3306, user='root', password='your_password', db='your_database') # 创建游标对象 cursor = conn.cursor() # 插入数据 sql_insert = "INSERT INTO your_table (name, age, gender) VALUES (%s, %s, %s)" data = ('John', 25, 'male') cursor.execute(sql_insert, data) conn.commit() # 更新数据 sql_update = "UPDATE your_table SET age = %s WHERE name = %s" data = (30, 'John') cursor.execute(sql_update, data) conn.commit() # 删除数据 sql_delete = "DELETE FROM your_table WHERE name = %s" data = ('John',) cursor.execute(sql_delete, data) conn.commit() # 查询数据 sql_select = "SELECT * FROM your_table WHERE name = %s" data = ('John',) cursor.execute(sql_select, data) results = cursor.fetchall() # 打印结果 for row in results: name = row[0] age = row[1] gender = row[2] print(f"name: {name}, age: {age}, gender: {gender}") # 关闭游标和连接 cursor.close() conn.close() ``` 需要注意的是,以上代码中的参数需要根据您自己的数据库配置进行修改,包括数据库地址、端口、用户名、密码、数据库名、数据表名等。同时,您需要安装pymysql库,可以通过以下命令进行安装: ```bash pip install pymysql ``` 希望这能帮助到您。如果您有其他问题,欢迎随时提出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱写代码的小朋友

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值