当前位置: 首页 > news >正文

PyMySQL库的使用方法

过程和步骤:

安装 PyMySQL

首先,需要使用 pip 安装 PyMySQL 库:

pip install pymysql

连接数据库

使用 PyMySQL.connect() 方法可以建立到 MySQL 数据库的连接:

import pymysql# 配置数据库连接参数
config = {'host': 'localhost',     # 数据库服务器地址'port': 3306,            # 数据库服务器端口'user': 'your_username', # 数据库用户名'password': 'your_password', # 数据库密码'database': 'your_database', # 要操作的数据库名'charset': 'utf8mb4'     # 使用的字符集
}# 建立连接
connection = pymysql.connect(**config)

创建游标对象

游标(Cursor)用于执行 SQL 语句和获取查询结果:

# 创建游标对象
cursor = connection.cursor()

执行 SQL 语句

使用游标的 execute() 方法可以执行 SQL 语句:

# 执行查询语句
cursor.execute("SELECT * FROM your_table")# 获取所有查询结果
results = cursor.fetchall()
for row in results:print(row)# 执行非查询语句(如 INSERT、UPDATE、DELETE)
cursor.execute("INSERT INTO your_table (column1, column2) VALUES (value1, value2)")

提交事务

对于非查询类的 SQL 语句,需要提交事务以确保更改生效:

connection.commit()

错误处理

使用 try...except 语句来处理可能发生的异常:

try:# 尝试执行一些操作pass
except pymysql.MySQLError as e:print(e)connection.rollback()  # 发生错误时回滚事务
finally:cursor.close()  # 关闭游标connection.close()  # 关闭连接

关闭连接

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

cursor.close()
connection.close()

示例代码

下面是一个使用 PyMySQL 执行查询和插入操作的完整示例:

import pymysql# 配置数据库连接参数
config = {'host': 'localhost','port': 3306,'user': 'your_username','password': 'your_password','database': 'your_database','charset': 'utf8mb4'
}# 建立连接
connection = pymysql.connect(**config)try:# 创建游标对象with connection.cursor() as cursor:# 执行查询cursor.execute("SELECT * FROM your_table")print("Query results:", cursor.fetchall())# 执行插入操作cursor.execute("INSERT INTO your_table (column1, column2) VALUES (%s, %s)", ('value1', 'value2'))# 提交事务connection.commit()except pymysql.MySQLError as e:print("Error: ", e)connection.rollback()
finally:# 关闭连接connection.close()

请注意,上述示例中的 'your_username', 'your_password', 'your_database''your_table' 需要替换为实际的数据库登录信息和表名。

http://www.lryc.cn/news/406037.html

相关文章:

  • iOS 创建一个私有的 CocoaPods 库
  • Linux_实现UDP网络通信
  • C# 代理模式
  • 【1】Python机器学习之基础概念
  • HashMap源码解析
  • [Javascript】前端面试基础3【每日学习并更新10】
  • C++自定义字典树结构
  • dockerfile部署wordpress
  • CSS(二)——CSS 背景
  • 开机出现grub无法进入系统_电脑开机出现grub解决方法
  • uboot 设置bootargs配置内核网络挂载根文件系统
  • Vue3+.NET6前后端分离式管理后台实战(三十一)
  • 22集 如何minimax密钥和groupid-《MCU嵌入式AI开发笔记》
  • 决策树的概念
  • C++《类和对象》(中)
  • SpringBoot中JSR303校验
  • 图像数据增强方法概述
  • 【学习笔记】无人机系统(UAS)的连接、识别和跟踪(五)-无人机跟踪
  • 分享从零开始学习网络设备配置--任务6.1 实现计算机的安全接入
  • 双向链表(C语言版)
  • 【算法/学习】前缀和差分
  • idea Project 不显示文件和目录
  • Linux--Socket编程预备
  • 100个python的基本语法知识【下】
  • Git如何将一个分支上的修改转移到另一个分支
  • jvm-证明cpu指令是乱序执行的案例
  • 《流程引擎原理与实践》开源电子书
  • 谷粒商城实战笔记-52~53-商品服务-API-三级分类-新增-修改
  • uni-app 影视类小程序开发从零到一 | 开源项目分享
  • Python使用正则替换字符串