使用Python操作MySQL数据库:入门指南和实际案例

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

目录

  1. 简介
  2. 安装MySQL Connector
  3. 建立连接
  4. 创建数据库
  5. 创建表
  6. 插入数据
  7. 查询数据
  8. 更新数据
  9. 删除数据
  10. 详细代码案例
  11. 总结

1. 简介

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

2. 安装MySQL Connector

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

bash
复制代码
pip install mysql-connector-python

3. 建立连接

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

python
复制代码
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的数据库:

python
复制代码
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列:

python
复制代码
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表插入一条数据:

python
复制代码
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", "[email protected]")
cursor.execute(sql, val)

cnx.commit()

print(f"{cursor.rowcount} record(s) inserted!")
cnx.close()

7. 查询数据

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

python
复制代码
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表中的一条数据:

python
复制代码
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 = ("[email protected]", "John Doe")
cursor.execute(sql, val)

cnx.commit()

print(f"{cursor.rowcount} record(s) updated!")
cnx.close()

9. 删除数据

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

python
复制代码
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. 详细代码案例

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

python
复制代码
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", "[email protected]")
create_user("Bob", "[email protected]")

# 查询所有用户
users = get_all_users()
print("All users:")
for user in users:
    print(user)

# 更新用户邮箱
update_user_email("Alice", "[email protected]")

# 查询所有用户
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感兴趣,想通过学习Python获取更高的薪资,那下面这套Python学习资料一定对你有用!

资料包括:Python安装包+激活码、Python web开发,Python爬虫,Python数据分析,人工智能、机器学习等学习教程。0基础小白也能听懂、看懂,跟着教程走,带你从零基础系统性地学好Python!

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述
二、Python学习软件

工欲善其事,必先利其器。学习Python常用的开发软件都在这里了!
在这里插入图片描述
三、Python入门学习视频

还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~在这里插入图片描述

四、Python练习题

每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
在这里插入图片描述

五、Python实战案例

光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。这份资料也包含在内的哈~在这里插入图片描述

六、Python面试资料

我们学会了Python之后,有了技能就可以出去找工作啦!下面这些面试题是都来自阿里、腾讯、字节等一线互联网大厂,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述
七、资料领取

上述完整版Python全套学习资料已经上传CSDN官方,需要的小伙伴可自行微信扫描下方CSDN官方认证二维码免费领取

猜你喜欢

转载自blog.csdn.net/Python966/article/details/132148008