【Python】连接MySQL数据库:详细教程与示例代码

文章目录

    • 1. 安装必要的库
    • 2. 建立与MySQL的连接
    • 3. 执行SQL查询
    • 4. 插入数据
    • 5. 更新数据
    • 6. 删除数据
    • 7. 错误处理
    • 8. 小结

在数据驱动的开发中,连接数据库是一个至关重要的技能。Python作为一门强大的编程语言,提供了多种方式连接并操作MySQL数据库。本文将详细介绍如何在Python中连接MySQL数据库,包括所需库的安装、基本连接方法、执行查询、处理结果集以及错误处理。

1. 安装必要的库

在Python中,常用的MySQL连接库是mysql-connector-pythonPyMySQL。以下示例将使用mysql-connector-python,它是MySQL官方提供的连接器。

使用pip安装mysql-connector-python

pip install mysql-connector-python

使用pip安装mysql-connector-python库,这个库提供了与MySQL数据库通信的功能。

2. 建立与MySQL的连接

安装完库后,就可以在Python中建立与MySQL的连接了。以下是一个基本的连接示例:

import mysql.connector# 建立连接
conn = mysql.connector.connect(host='localhost',user='yourusername',password='yourpassword',database='yourdatabase'
)print("连接成功")
conn.close()
  • import mysql.connector:导入mysql.connector模块。
  • mysql.connector.connect():建立与MySQL数据库的连接,参数包括主机名、用户名、密码和数据库名。
  • conn.close():关闭数据库连接。

3. 执行SQL查询

建立连接后,就可以执行SQL查询。以下是一个查询示例:

import mysql.connectorconn = mysql.connector.connect(host='localhost',user='yourusername',password='yourpassword',database='yourdatabase'
)cursor = conn.cursor()# 执行查询
cursor.execute("SELECT * FROM yourtable")# 获取查询结果
results = cursor.fetchall()for row in results:print(row)cursor.close()
conn.close()
  • cursor = conn.cursor():创建一个游标对象,用于执行SQL查询。
  • cursor.execute("SELECT * FROM yourtable"):执行SQL查询。
  • results = cursor.fetchall():获取所有查询结果。
  • for row in results:遍历结果集并打印每一行。
  • cursor.close():关闭游标。
  • conn.close():关闭数据库连接。

4. 插入数据

除了查询数据,还可以使用Python插入数据。以下是一个插入数据的示例:

import mysql.connectorconn = mysql.connector.connect(host='localhost',user='yourusername',password='yourpassword',database='yourdatabase'
)cursor = conn.cursor()# 插入数据
sql = "INSERT INTO yourtable (column1, column2) VALUES (%s, %s)"
val = ("value1", "value2")
cursor.execute(sql, val)conn.commit()print(cursor.rowcount, "记录插入成功")cursor.close()
conn.close()
  • sql = "INSERT INTO yourtable (column1, column2) VALUES (%s, %s)":定义插入SQL语句。
  • val = ("value1", "value2"):定义插入的数据。
  • cursor.execute(sql, val):执行插入操作。
  • conn.commit():提交事务。
  • cursor.rowcount:获取插入的记录数。

5. 更新数据

更新数据与插入数据类似,只需更改SQL语句。以下是一个更新数据的示例:

import mysql.connectorconn = mysql.connector.connect(host='localhost',user='yourusername',password='yourpassword',database='yourdatabase'
)cursor = conn.cursor()# 更新数据
sql = "UPDATE yourtable SET column1 = %s WHERE column2 = %s"
val = ("newvalue", "value2")
cursor.execute(sql, val)conn.commit()print(cursor.rowcount, "记录更新成功")cursor.close()
conn.close()
  • sql = "UPDATE yourtable SET column1 = %s WHERE column2 = %s":定义更新SQL语句。
  • val = ("newvalue", "value2"):定义更新的数据。
  • cursor.execute(sql, val):执行更新操作。
  • conn.commit():提交事务。
  • cursor.rowcount:获取更新的记录数。

6. 删除数据

删除数据也与插入和更新类似。以下是一个删除数据的示例:

import mysql.connectorconn = mysql.connector.connect(host='localhost',user='yourusername',password='yourpassword',database='yourdatabase'
)cursor = conn.cursor()# 删除数据
sql = "DELETE FROM yourtable WHERE column2 = %s"
val = ("value2",)
cursor.execute(sql, val)conn.commit()print(cursor.rowcount, "记录删除成功")cursor.close()
conn.close()
  • sql = "DELETE FROM yourtable WHERE column2 = %s":定义删除SQL语句。
  • val = ("value2",):定义删除的数据条件。
  • cursor.execute(sql, val):执行删除操作。
  • conn.commit():提交事务。
  • cursor.rowcount:获取删除的记录数。

7. 错误处理

在数据库操作过程中,可能会遇到各种错误,如连接失败、SQL语法错误等。可以使用try-except语句进行错误处理。

import mysql.connector
from mysql.connector import Errortry:conn = mysql.connector.connect(host='localhost',user='yourusername',password='yourpassword',database='yourdatabase')if conn.is_connected():print("连接成功")except Error as e:print("错误:", e)finally:if conn.is_connected():conn.close()print("连接已关闭")
  • try块:尝试建立数据库连接。
  • except Error as e:捕获并打印错误信息。
  • finally块:确保连接关闭。

8. 小结

本文详细介绍了如何在Python中连接并操作MySQL数据库,包括库的安装、基本连接、执行查询、插入数据、更新数据、删除数据以及错误处理。掌握这些技能将大大提高数据驱动开发的效率和可靠性。数据库操作是Python编程中的重要部分,熟练掌握这些知识将为开发工作带来巨大帮助。

推荐我的相关专栏:

  • python 错误记录
  • python 笔记
  • 数据结构

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/48806.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【时时三省】(C语言基础)函数和数组

山不在高,有仙则名。水不在深,有龙则灵。 ——csdn时时三省 函数 跟数学里面的函数很相似 数组 一组相同类型的元素的集合 比如把5个整形1-5存起来 int arr[10]={1,2,3&#x…

浏览器打开抽奖系统html

<!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>在线抽奖 随机选取 自动挑选</title> <script src"https://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script> <style> body {…

antdesgin table 组件下载成excel

文章目录 发现宝藏一、需求二、报错 发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。【宝藏入口】。 一、需求 原组件如下&#xff0c;需要添加下载功能 import React, { useState } from rea…

Spring Boot + Spring Cloud 入门

运行配置 java -jar spring-boot-config-0.0.1-SNAPSHOT.jar --spring.profiles.activetest --my1.age32 --debugtrue "D:\Program Files\Redis\redis-server.exe" D:\Program Files\Redis\redis.windows.conf "D:\Program Files\Redis\redis-cli.exe" &q…

Go语言 Import导入

本文主要介绍Go语言import导入使用时注意事项和功能实现示例。 目录 Import 创建功能文件夹 加法 减法 主函数 优化导入的包名 .引入方法 总结 Import 创建功能文件夹 做一个计算器来演示&#xff0c;首先创建test文件夹。 加法 在test文件夹中创建add文件夹&#xff…

《简历宝典》17 - 简历中“技术能力”,如何丰满且有层次,前端篇

这一节开始对技术能力模块做讲解&#xff0c;我们身边的这些互联网IT从业者们&#xff0c;前端开发、Java开发、软件测试又或者是其他职位的开发者们&#xff0c;技术能力这个模块是绕不过去的&#xff0c;从简历上看&#xff0c;这个模块体现了我们之前软件工作生涯中的技术功…

大厂面试-基本功

大厂面试第4季 服务可用性多少个9是什么意思遍历集合add或remove操作bughashcode冲突案例BigdecimalList去重复IDEA Debugger测试框架ThreaLocal父子线程数据同步 InheritableThreadLocal完美解决线程数据同步方案 TransmittableThreadLocal 服务可用性多少个9是什么意思 遍历集…

【C++高阶】哈希函数底层原理探索:从算法设计到实现优化

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ ⏩收录专栏⏪&#xff1a;C “ 登神长阶 ” &#x1f921;往期回顾&#x1f921;&#xff1a;模拟实现 map与set &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀哈希 &#x1f4da;1. unord…

(ISPRS,2021)具有遥感知识图谱的鲁棒深度对齐网络用于零样本和广义零样本遥感图像场景分类

文章目录 Robust deep alignment network with remote sensing knowledge graph for zero-shot and generalized zero-shot remote sensing image scene classification相关资料摘要引言遥感知识图谱的表示学习遥感知识图谱的构建实体和关系的语义表示学习创建遥感场景类别的语…

ts踩坑!vue3中ts文件用export导出公共方法的ts类型定义

当我们有一个ts文件&#xff0c;定义并export出该function&#xff0c;其中方法里边有定义的变量&#xff0c;方法、钩子函数等多种&#xff0c;并最终return出该变量、方法。 此时 ts规则校验会让我们返回该函数类型。如下 export default function () {const chart ref();c…

Java基础-序列化、泛型、1.8新特性、其他

目录 序列化 什么是序列化&#xff1f;什么是反序列化&#xff1f; Serializable 接口有什么用&#xff1f; serialVersionUID 又有什么用&#xff1f; Java 序列化不包含静态变量吗&#xff1f; 如果有些变量不想序列化&#xff0c;怎么办&#xff1f; 说说有几种序列化…

Yolo-World网络模型结构及原理分析(一)——YOLO检测器

文章目录 概要一、整体架构分析二、详细结构分析YOLO检测器1. Backbone2. Head3.各模块的过程和作用Conv卷积模块C2F模块BottleNeck模块SPPF模块Upsampling模块Concat模块 概要 尽管YOLO&#xff08;You Only Look Once&#xff09;系列的对象检测器在效率和实用性方面表现出色…

计网:物理层

写在开头&#xff1a;物理层就负责传送比特0和1&#xff0c; 本质上理解物理层就是理解传输介质哪个表示比特0和1&#xff0c;如&#xff1a;高电平表示1、低电平表示0等 物理层主要任务&#xff1a; 机械特性&#xff1a;指明接口所用接线器的形状和尺寸、引脚数目和排列、固…

【BUG】已解决:requests.exceptions.ProxyError: HTTPSConnectionPool

已解决&#xff1a;requests.exceptions.ProxyError: HTTPSConnectionPool 目录 已解决&#xff1a;requests.exceptions.ProxyError: HTTPSConnectionPool 【常见模块错误】 原因分析 解决方案 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&am…

Android Studio 输出信息出现乱码

现象 解决办法 一、第一步 二、第二步 添加如下代码&#xff1a; 直接复制进去即可 -Dfile.encodingUTF-8 注意 &#xff1a;最后&#xff0c;添加后重新编译工程&#xff0c;如果还是发现乱码&#xff0c;则需要关闭Android Studio重新启即可

Spring Security之安全异常处理

前言 在我们的安全框架中&#xff0c;不管是什么框架&#xff08;包括通过过滤器自定义&#xff09;都需要处理涉及安全相关的异常&#xff0c;例如&#xff1a;登录失败要跳转到登录页&#xff0c;访问权限不足要返回页面亦或是json。接下来&#xff0c;我们就看看Spring Sec…

Docker核心技术:容器技术要解决哪些问题

云原生学习路线导航页&#xff08;持续更新中&#xff09; 本文是 Docker核心技术 系列文章&#xff1a;容器技术要解决哪些问题&#xff0c;其他文章快捷链接如下&#xff1a; 应用架构演进容器技术要解决哪些问题&#xff08;本文&#xff09;Docker的基本使用Docker是如何实…

【AI大模型】生成式AI的未来——CHAT还是AGENT?

【AI大模型】CHAt还是AGENt&#xff1f; 最近&#xff0c;许多人工智能公司或者部门都在针对Agent——人工智能体有所动作。 例如&#xff1a; 文心一言智能体 Gnomic智能体 英伟达视觉AI代理 那么人工智能概念中的智能体Agent到底是什么呢&#xff1f;它又为何会突然在人工智…

虚拟化环境中如何实现以业务为中心的网络隔离?Everoute 推出虚拟专有云网络(VPC)功能

目前&#xff0c;不少企业都利用云计算和虚拟化技术提升 IT 系统灵活性、敏捷性和成本效益。然而&#xff0c;云环境的“多租户”特性也为业务安全带来了新的挑战&#xff0c;如何保障不同业务主体或租户之间的数据安全和网络隔离&#xff0c;成为企业关注的焦点。 作为 Smart…

可控硅触发板选型指南

可控硅触发板(SCR Trigger Board)是一种用于触发和控制可控硅(SCR)导通的电子设备。在电力控制、电机驱动、变频调速等领域中&#xff0c;可控硅触发板发挥着至关重要的作用。它通过精确的触发信号&#xff0c;实现对可控硅的启动和控制&#xff0c;从而实现对电路的开关和电流…