上一章我们已经学习了如何下载和使用MySQL,还学会了通过终端和图像管理软件MySQL Workbech操作MySQL数据库。在真正的软件项目中,由于数据的读写极其繁琐和复杂,我们是无法单单靠手动操作SQL语句管理数据库的,必须通过编程语言对数据库进行操作才能有效地管理数据库。那么这一章,我们就来学习如何使用编程语言Python自动化操作MySQL数据库。
安装包下载
首先我们需要先在本地电脑上安装Python,安装过程可以考察我发布过的《Python一周入门教程》第一章中的环境搭建。
安装好Python之后,我们需要下载用来连接Python和MySQL的包,大家可以使用pip包管理器,安装mysql-connetor包。使用Mac的小伙伴可以使用以下的命令进行安装:
pip3 install mysql-connector-python
下载完毕后,大家可以编辑以下的Python脚本 mysql_test.py ,如果运行完毕没有错误,就代表能使用Python正常操作MySQL了:
import mysql.connector
mysql_connection = mysql.connector.connect(
host="localhost",
user="root",
password="password"
)
print(mysql_connection)
其中connect函数的user和password参数需要根据自己设定的用户名和密码进行设置。
要注意命名的重要性,不要给脚本取 mysql.py 这样和包名有冲突的名字,可以遵循这样的命名格式:xxx_xxx.py
Python操作MySQL
接下来我们就使用Python对MySQL进行常见的CRUD操作。
以下的Python脚本会在MySQL中创建一个PythonDB数据库。
创建数据库
import mysql.connector
mysql_connection = mysql.connector.connect(user='root', password='password', host='localhost')
cursor = mysql_connection.cursor()
cursor.execute("CREATE DATABASE PythonDB")
运行脚本后,我们就会在MySQL中创建一个名叫PythonDB的数据库。
创建Students表
创建完PythonDB数据库后,我们可以在PythonDB数据库中创建表格,以下的脚本就会在PythonDB数据库中创建Students表:
import mysql.connector
mysql_connection = mysql.connector.connect(user='root', password='password', host='localhost', database="PythonDB")
cursor = mysql_connection.cursor()
cursor.execute("CREATE TABLE Students (StudentID int PRIMARY KEY, Name VARCHAR(255), City VARCHAR(255))")
添加Students数据
创建完Students表之后,我们能使用以下的脚本添加5个具体的学生数据:
import mysql.connector
mysql_connection = mysql.connector.connect(user='root', password='password', host='localhost', database="PythonDB")
sql = "INSERT INTO Students (StudentID, Name, City) VALUES (%s, %s, %s)"
val = [
(1, 'Enoch', 'Los Angeles'),
(2, 'David', 'New York City'),
(3, 'Kevin', 'Shanghai'),
(4, 'Frank', 'Beijing'),
(5, 'Alice', 'Tokyo'),
]
cursor = mysql_connection.cursor()
for student in val:
cursor.execute(sql, student)
mysql_connection.commit()
查询数据
存储完学生数据后,我们可以使用以下脚本查询学生数据,并打印出学生的信息:
import mysql.connector
mysql_connection = mysql.connector.connect(user='root', password='password', host='localhost', database='PythonDB')
cursor = mysql_connection.cursor()
cursor.execute('SELECT * FROM Students')
values = cursor.fetchall()
print(values)
mysql_connection.close()
数据库操作整合
上面的每个脚本只能单独做一个操作,我们可以将多个操作集成到一个脚本中:
import mysql.connector
class DBManager:
def __init__(self, user, password, host, database):
self.mysql_connection = mysql.connector.connect(user=user, password=password, host=host, database=database)
self.cursor = self.mysql_connection.cursor()
def insert_student(self, student_info):
sql = "INSERT INTO Students (StudentID, Name, City) VALUES (%s, %s, %s)"
self.cursor.execute(sql, student_info)
def show_data(self, table_name):
self.cursor.execute(f"SELECT * FROM {table_name}")
values = self.cursor.fetchall()
for student in values:
print(student)
db_manager = DBManager('root', 'password', 'localhost', 'PythonDB')
# Insert new students
students = [
(6, 'Frank', 'Beijing'),
(7, 'Alice', 'Tokyo'),
]
for student in students:
db_manager.insert_student(student)
# Check students
db_manager.show_data("Students")
这个脚本先连接到PythonDB数据库,然后插入两个额外的学生,最后将所有的学生数据显示出来。
以上就是常用的使用Python操作MySQL的方法,大家可以撸起袖子,自创一些脚本,创建一些别的表格和数据。
这就是SQL入门的基本内容了,通过这个系列的学习,相信大家已经掌握了基本的SQL语句,也学习了如何使用MySQL,并能够编辑Python脚本自动化操作数据库。在未来的教程中,以诺希望制作一个网站搭建教程,通过从0到1实现一个博客网站,帮助大家更好地理解数据库在真实项目中的应用,请大家持续关注~。