超详细!教你如何使用Python连接MySQL数据库

超详细!教你如何使用Python连接MySQL数据库

数据库编程是在应用程序中与数据库交互和管理数据的关键部分。MySQL是一种流行的关系型数据库管理系统(RDBMS),在Python中进行MySQL数据库编程相对容易。

本文介绍如何使用Python进行MySQL数据库编程,包括连接数据库、执行SQL查询、插入、更新和删除数据等操作。

目录

安装MySQL驱动连接MySQL数据库创建数据库创建数据表插入数据查询数据更新数据删除数据执行事务关闭数据库连接示例:一个完整的MySQL数据库编程示例安全性注意事项总结

1. 安装MySQL驱动

在开始之前,需要安装Python的MySQL数据库驱动程序。最常用的驱动程序之一是mysql-connector-python

使用pip进行安装:

pip install mysql-connector-python

2. 连接MySQL数据库

在进行任何数据库操作之前,首先需要建立与MySQL数据库的连接。通常,需要提供数据库的主机名、用户名、密码和数据库名称。

以下是连接到MySQL数据库的示例:

import mysql.connector

# 创建数据库连接

db = mysql.connector.connect(

host="localhost", # MySQL服务器地址

user="username", # 用户名

password="password", # 密码

database="mydatabase" # 数据库名称

)

# 创建游标对象,用于执行SQL查询

cursor = db.cursor()

3. 创建数据库

创建一个新的数据库,可以执行以下操作:

# 创建一个名为"mydatabase"的新数据库

cursor.execute("CREATE DATABASE mydatabase")

4. 创建数据表

在数据库中,数据以表格形式组织。在创建表格之前,需要定义表格的结构,包括列名、数据类型和约束。

以下是一个示例:

# 创建一个名为"customers"的数据表

cursor.execute("CREATE TABLE customers (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255), address VARCHAR(255))")

5. 插入数据

插入数据是将数据添加到数据表中的过程。可以使用SQL的INSERT INTO语句来执行插入操作。

以下是一个示例:

# 插入一条记录到"customers"表中

sql = "INSERT INTO customers (name, address) VALUES (%s, %s)"

values = ("John Smith", "123 Main St")

cursor.execute(sql, values)

# 提交更改到数据库

db.commit()

print(f"插入了 {cursor.rowcount} 条记录")

6. 查询数据

查询数据是从数据库中检索数据的过程。使用SQL的SELECT语句来执行查询操作。

以下是一个示例:

# 查询所有记录

cursor.execute("SELECT * FROM customers")

# 获取查询结果

results = cursor.fetchall()

for row in results:

print(row)

7. 更新数据

更新数据是修改现有数据的过程。使用SQL的UPDATE语句来执行更新操作。

以下是一个示例:

# 更新"customers"表中id为1的记录

sql = "UPDATE customers SET address = %s WHERE id = %s"

values = ("456 Elm St", 1)

cursor.execute(sql, values)

# 提交更改到数据库

db.commit()

print(f"更新了 {cursor.rowcount} 条记录")

8. 删除数据

删除数据是从数据库中删除数据的过程。使用SQL的DELETE语句来执行删除操作。

以下是一个示例:

# 删除"customers"表中id为1的记录

sql = "DELETE FROM customers WHERE id = %s"

values = (1,)

cursor.execute(sql, values)

# 提交更改到数据库

db.commit()

print(f"删除了 {cursor.rowcount} 条记录")

9. 执行事务

事务是一组SQL操作,要么全部成功,要么全部失败。在某些情况下,需要使用事务来确保数据库的完整性。

以下是一个示例:

try:

db.start_transaction()

# 执行一系列SQL操作

cursor.execute("INSERT INTO customers (name, address) VALUES (%s, %s)", ("Alice", "789 Oak St"))

cursor.execute("UPDATE customers SET address = %s WHERE id = %s", ("789 Elm St", 2))

db.commit() # 提交事务

except:

db.rollback() # 事务回滚,撤销之前的操作

10. 关闭数据库连接

在完成数据库操作后,不要忘记关闭数据库连接,以释放资源。

cursor.close() # 关闭游标

db.close() # 关闭数据库连接

11. 示例:一个完整的MySQL数据库编程示例

以下是一个完整的MySQL数据库编程示例,包括连接数据库、创建表格、插入数据、查询数据、更新数据和删除数据:

import mysql.connector

# 创建数据库连接

db = mysql.connector.connect(

host="localhost",

user="username",

password="password",

database="mydatabase"

)

# 创建游标对象

cursor = db.cursor()

# 创建一个名为"customers"的数据表

cursor.execute("CREATE TABLE customers (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255), address VARCHAR(255))")

# 插入记录

sql = "INSERT INTO customers (name, address) VALUES (%s, %s)"

values = [("John Smith", "123 Main St"), ("Alice Johnson", "456 Elm St")]

cursor.executemany(sql, values)

db.commit()

# 查询记录

cursor.execute("SELECT * FROM customers")

results = cursor.fetchall()

for row in results:

print(row)

# 更新记录

sql = "UPDATE customers SET address = %s WHERE name = %s"

values = ("789 Oak St", "Alice Johnson")

cursor.execute(sql, values)

db.commit()

# 删除记录

sql = "DELETE FROM customers WHERE name = %s"

values = ("John Smith",)

cursor.execute(sql, values)

db.commit()

# 关闭游标和数据库连接

cursor.close()

db.close()

12.安全性注意事项

在进行数据库编程时,请务必注意安全性。避免直接将用户提供的数据插入SQL语句,以防止SQL注入攻击。可以使用参数化查询或ORM(对象关系映射)来增强安全性。

总结

MySQL数据库编程是Python应用程序的关键组成部分。本文介绍了如何连接数据库、创建数据表、插入、查询、更新和删除数据,以及执行事务。通过这些操作,您可以有效地管理数据,并确保数据的完整性和安全性。希望本文对您在Python中进行MySQL数据库编程有所帮助。

---------------------------END---------------------------

题外话

当下这个大数据时代不掌握一门编程语言怎么跟的上时代呢?当下最火的编程语言Python前景一片光明!如果你也想跟上时代提升自己那么请看一下.

感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。 👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

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

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

六、面试宝典

简历模板 👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

若有侵权,请联系删除

养生小贴士

新手必看!不可不知「香氛蜡烛的使用方法」及「蜡烛必备工具」推荐,第一次点燃该注意什么?一次搞懂!
央的笔画顺序
💡 小知识

央的笔画顺序

📅 06-29 👍 375
朗逸和速派点评对比
💡 小知识

朗逸和速派点评对比

📅 07-03 👍 534