我们将通过一个实例来探讨如何使用Python与MySQL数据库进行交互,以构建一个简单的学生信息管理系统。这个系统将能够执行基本的CRUD(创建(Create)、读取(Retrieve)、更新(Update)、删除(Delete))操作,以管理学生信息。我们将使用`mysql-connector-python`库来连接MySQL数据库,该库是官方推荐的Python MySQL驱动程序。
#### 准备工作
首先,确保你的环境中安装了MySQL服务器和Python。接下来,安装`mysql-connector-python`库:
```bash
pip install mysql-connector-python
```
#### 数据库准备
1. **创建数据库**: 登录到MySQL客户端,创建一个名为`student_manager`的数据库。
```sql
CREATE DATABASE student_manager;
USE student_manager;
```
2. **创建表**: 创建一个名为`students`的表,用来存储学生信息。
```sql
CREATE TABLE students (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50) NOT NULL,age INT,class VARCHAR(10)
);
```
#### Python代码实现
接下来,我们使用Python编写一个简单的脚本来实现学生信息管理系统的功能。```python
import mysql.connector
from mysql.connector import Errordef create_connection():"""创建数据库连接"""connection = Nonetry:connection = mysql.connector.connect(host='localhost',user='your_username', # 替换为你的MySQL用户名password='your_password', # 替换为你的MySQL密码database='student_manager')print("Connection to MySQL DB successful")except Error as e:print(f"The error '{e}' occurred")return connectiondef execute_query(connection, query):"""执行SQL查询"""cursor = connection.cursor()try:cursor.execute(query)connection.commit()print("Query executed successfully")except Error as e:print(f"The error '{e}' occurred")def fetch_data(connection, query):"""获取数据"""cursor = connection.cursor()result = Nonetry:cursor.execute(query)result = cursor.fetchall()return resultexcept Error as e:print(f"The error '{e}' occurred")finally:cursor.close()def main():connection = create_connection()# 插入数据示例insert_query = """INSERT INTO students (name, age, class) VALUES('Alice', 20, 'A1'),('Bob', 22, 'B2'),('Charlie', 19, 'A1');"""execute_query(connection, insert_query)# 查询所有学生select_query = "SELECT * FROM students"students = fetch_data(connection, select_query)for student in students:print(student)# 更新数据示例update_query = "UPDATE students SET class = 'C3' WHERE name = 'Bob'"execute_query(connection, update_query)# 删除数据示例delete_query = "DELETE FROM students WHERE name = 'Charlie'"execute_query(connection, delete_query)connection.close()if __name__ == '__main__':main()
```
#### 解释
- **`create_connection`**: 创建一个到MySQL数据库的连接。
- **`execute_query`**: 执行SQL查询,用于插入、更新和删除操作。
- **`fetch_data`**: 执行查询并返回所有结果,主要用于检索数据。
- **`main`**: 主函数,展示了如何使用上述函数完成CRUD操作。首先插入几条示例数据,然后查询所有学生信息并打印,接着更新和删除学生记录。
#### 注意事项
- 在实际应用中,请确保替换`your_username`和`your_password`为你的MySQL数据库的实际登录凭证。
- 本示例中的SQL语句是硬编码的,实际开发中可能需要根据用户输入动态构建SQL语句,注意防范SQL注入攻击。
- 在处理完数据库操作后,记得关闭连接以释放资源。
为了将上述Python与MySQL交互的简单学生信息管理系统以网页的形式展示,我们可以使用Flask框架,这是一个轻量级的Web服务器网关接口(WSGI)框架,非常适合小型应用和初学者学习Web开发。下面是如何将上述功能转化为一个简单的网页应用的示例。
### 安装Flask
首先,确保安装Flask和Flask-MySQL库:
```bash
pip install Flask flask-mysqldb
```
### 编写Flask应用
接下来,创建一个名为`app.py`的文件,编写Flask应用代码:```python
from flask import Flask, render_template, request, redirect, url_for
from flask_mysqldb import MySQLapp = Flask(__name__)# 配置MySQL
app.config['MYSQL_HOST'] = 'localhost'
app.config['MYSQL_USER'] = 'your_username' # 替换为你的MySQL用户名
app.config['MYSQL_PASSWORD'] = 'your_password' # 替换为你的MySQL密码
app.config['MYSQL_DB'] = 'student_manager'mysql = MySQL(app)@app.route('/')
def index():cur = mysql.connection.cursor()cur.execute('SELECT * FROM students')data = cur.fetchall()cur.close()return render_template('index.html', students=data)@app.route('/add_student', methods=['POST'])
def add_student():if request.method == 'POST':name = request.form['name']age = request.form['age']class_ = request.form['class']cur = mysql.connection.cursor()cur.execute('INSERT INTO students (name, age, class) VALUES (%s, %s, %s)', (name, age, class_))mysql.connection.commit()cur.close()return redirect(url_for('index'))@app.route('/delete/<string:id>')
def delete_student(id):cur = mysql.connection.cursor()cur.execute('DELETE FROM students WHERE id = %s', (id,))mysql.connection.commit()cur.close()return redirect(url_for('index'))if __name__ == '__main__':app.run(debug=True)
```
### 创建HTML模板
在你的项目目录下创建一个名为`templates`的文件夹,并在其中创建一个`index.html`文件,用于展示学生列表和添加学生的表单:
```html
<!doctype html>
<html>
<head><title>学生信息管理系统</title><!-- 内联样式 --><style>body {font-family: Arial, sans-serif;margin: 20px;}h2 {color: #4CAF50;margin-bottom: 10px;}table {width: 100%;border-collapse: collapse;}th, td {padding: 15px;text-align: left;border: 1px solid #ddd;}th {background-color: #f2f2f2;font-weight: bold;}tr:nth-child(even) {background-color: #f2f2f2;}tr:hover {background-color: #ddd;}form input[type="submit"] {background-color: #4CAF50;color: white;padding: 8px 16px;border: none;cursor: pointer;}form input[type="submit"]:hover {background-color: #45a049;}</style>
</head>
<body><h2>学生列表</h2><table border="1"><tr><th>ID</th><th>姓名</th><th>年龄</th><th>班级</th><th>操作</th></tr><!-- 假设这里由后端动态填充学生数据 --><!-- 示例数据,实际应用中将由Flask动态生成 -->{% for student in students %}<tr><td>{{ student[0] }}</td><td>{{ student[1] }}</td><td>{{ student[2] }}</td><td>{{ student[3] }}</td><td><a href="{{ url_for('delete_student', id=student[0]) }}">删除</a></td></tr>{% endfor %}</table><h2>添加学生</h2><form action="{{ url_for('add_student') }}" method="post">姓名:<input type="text" name="name"><br>年龄:<input type="number" name="age"><br>班级:<input type="text" name="class"><br><input type="submit" value="添加"></form>
</body>
</html>
通过这个简单的例子,我们不仅学习了如何使用Python与MySQL进行交互,还了解了如何构建一个基础的数据库应用程序框架。希望这能为你进一步探索数据库管理和Python编程提供一个良好的起点。