Python操作MySQL数据库的入门指南

 更新时间:2023年06月20日 15:29:22   作者:AIHE  
MySQL是一种关系型数据库管理系统,广泛应用于各种应用程序和网站,在本篇技术博客中,我们将探讨如何使用Python操作MySQL数据库,需要的可以收藏一下

在本篇技术博客中,我们将探讨如何使用Python操作MySQL数据库。我们将首先介绍如何建立连接,然后展示如何执行基本的数据库操作(如创建表、插入数据、查询数据等)。最后,我们将通过一个详细的代码案例来巩固所学内容。

1. 简介

MySQL是一种关系型数据库管理系统,广泛应用于各种应用程序和网站。Python提供了多种库来与MySQL数据库进行交互,本文将使用官方推荐的mysql-connector-python库。

2. 安装MySQL Connector

在开始之前,确保已经安装了mysql-connector-python库。如果尚未安装,可以使用以下命令进行安装:

pip install mysql-connector-python

3. 建立连接

为了与MySQL数据库进行交互,我们首先需要建立连接。以下代码展示了如何使用mysql.connector.connect()方法建立连接:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password"
)
print("Connected to MySQL server!")
cnx.close()

4. 创建数据库

连接到MySQL服务器后,我们可以创建一个新的数据库。以下代码展示了如何使用CREATE DATABASE语句创建一个名为mydb的数据库:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password"
)
cursor = cnx.cursor()
cursor.execute("CREATE DATABASE mydb")
print("Database 'mydb' created!")
cnx.close()

5. 创建表

创建数据库后,我们需要在其中创建表。以下代码展示了如何创建一个名为users的表,并为其添加idnameemail列:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="mydb"
)
cursor = cnx.cursor()
cursor.execute("""
CREATE TABLE users (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(100),
  email VARCHAR(100)
)
""")
print("Table 'users' created!")
cnx.close()

6. 插入数据

创建表后,我们可以向其中插入数据。以下代码展示了如何向users表插入一条数据:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="mydb"
)
cursor = cnx.cursor()
sql = "INSERT INTO users (name, email) VALUES (%s, %s)"
val = ("John Doe", "john.doe@example.com")
cursor.execute(sql, val)
cnx.commit()
print(f"{cursor.rowcount} record(s) inserted!")
cnx.close()

7. 查询数据

我们可以使用SELECT语句从表中查询数据。以下代码展示了如何从users表中查询所有数据:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="mydb"
)
cursor = cnx.cursor()
cursor.execute("SELECT * FROM users")
for row in cursor.fetchall():
    print(row)
cnx.close()

8. 更新数据

要更新表中的数据,我们可以使用UPDATE语句。以下代码展示了如何更新users表中的一条数据:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="mydb"
)
cursor = cnx.cursor()
sql = "UPDATE users SET email = %s WHERE name = %s"
val = ("john.doe@newexample.com", "John Doe")
cursor.execute(sql, val)
cnx.commit()
print(f"{cursor.rowcount} record(s) updated!")
cnx.close()

9. 删除数据

要从表中删除数据,我们可以使用DELETE语句。以下代码展示了如何从users表中删除一条数据:

import mysql.connector
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="mydb"
)
cursor = cnx.cursor()
sql = "DELETE FROM users WHERE name = %s"
val = ("John Doe",)
cursor.execute(sql, val)
cnx.commit()
print(f"{cursor.rowcount} record(s) deleted!")
cnx.close()

10. 详细代码案例

在本节中,我们将通过一个实际案例来巩固前面所学的内容。我们将创建一个简单的应用程序,该程序可以将用户信息添加到数据库中,并根据需要查询、更新或删除这些信息。

import mysql.connector
def connect_to_db():
    return mysql.connector.connect(
        host="localhost",
        user="your_username",
        password="your_password",
        database="mydb"
    )
def create_user(name, email):
    cnx = connect_to_db()
    cursor = cnx.cursor()
    sql = "INSERT INTO users (name, email) VALUES (%s, %s)"
    val = (name, email)
    cursor.execute(sql, val)
    cnx.commit()
    cnx.close()
def get_all_users():
    cnx = connect_to_db()
    cursor = cnx.cursor()
    cursor.execute("SELECT * FROM users")
    result = cursor.fetchall()
    cnx.close()
    return result
def update_user_email(name, new_email):
    cnx = connect_to_db()
    cursor = cnx.cursor()
    sql = "UPDATE users SET email = %s WHERE name = %s"
    val = (new_email, name)
    cursor.execute(sql, val)
    cnx.commit()
    cnx.close()
def delete_user(name):
    cnx = connect_to_db()
    cursor = cnx.cursor()
    sql = "DELETE FROM users WHERE name = %s"
    val = (name,)
    cursor.execute(sql, val)
    cnx.commit()
    cnx.close()
# 添加用户
create_user("Alice", "alice@example.com")
create_user("Bob", "bob@example.com")
# 查询所有用户
users = get_all_users()
print("All users:")
for user in users:
    print(user)
# 更新用户邮箱
update_user_email("Alice", "alice@newexample.com")
# 查询所有用户
users = get_all_users()
print("All users after update:")
for user in users:
    print(user)
# 删除用户
delete_user("Bob")
# 查询所有用户
users = get_all_users()
print("All users after deletion:")
for user in users:
    print(user)

11. 总结

在本篇博客中,我们学习了如何使用Python操作MySQL数据库。我们讨论了如何建立连接、创建数据库和表、插入数据、查询数据、更新数据以及删除数据。最后,通过一个详细的代码案例来巩固所学知识。

如果你想深入了解mysql-connector-python库的其他功能,请查阅官方文档:MySQL Connector/Python Developer Guide

以上就是Python操作MySQL数据库的入门指南的详细内容,更多关于Python操作MySQL的资料请关注脚本之家其它相关文章!

相关文章

  • pygame游戏之旅 添加键盘按键的方法

    pygame游戏之旅 添加键盘按键的方法

    这篇文章主要为大家详细介绍了pygame游戏之旅的第4篇,教大家如何添加键盘按键,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Python处理菜单消息操作示例【基于win32ui模块】

    Python处理菜单消息操作示例【基于win32ui模块】

    这篇文章主要介绍了Python处理菜单消息操作,结合实例形式分析了Python基于win32ui模块实现菜单的创建及菜单项响应相关操作技巧,需要的朋友可以参考下
    2018-05-05
  • 基于pytorch实现运动鞋品牌识别功能

    基于pytorch实现运动鞋品牌识别功能

    这篇文章主要给大家介绍了关于如何基于pytorch实现运动鞋品牌识别功能,文中通过图文以及实例代码介绍的非常详细,对大家学习或者使用PyTorch具有一定的参考学习价值,需要的朋友可以参考下
    2024-02-02
  • python pyecharts库的用法大全

    python pyecharts库的用法大全

    这篇文章主要介绍了python pyecharts库的用法大全,pyecharts 是一个用于生成 Echarts 图表的类库,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-04-04
  • python之拟合的实现

    python之拟合的实现

    这篇文章主要介绍了python之拟合的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • 详解python程序中的多任务

    详解python程序中的多任务

    这篇文章主要介绍了python程序中多任务的相关资料,帮助大家更好的理解和学习python,感兴趣的朋友可以了解下
    2020-09-09
  • Python虚拟环境venv用法详解

    Python虚拟环境venv用法详解

    这篇文章主要介绍了Python虚拟环境venv用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Python pandas删除指定行/列数据的方法实例

    Python pandas删除指定行/列数据的方法实例

    这篇文章主要给大家介绍了关于Python pandas删除指定行/列数据的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01
  • python进行debug操作实战训练

    python进行debug操作实战训练

    debug是编码是非常重要的调试技巧,通过在运行过程中设置断点,帮助开发人员更好的理解运行过程,下面这篇文章主要给大家介绍了关于python进行debug操作的相关资料,需要的朋友可以参考下
    2023-06-06
  • pytorch训练神经网络爆内存的解决方案

    pytorch训练神经网络爆内存的解决方案

    这篇文章主要介绍了pytorch训练神经网络爆内存的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05

最新评论