按年份查询学生注册课程的查询
创始人
2024-11-03 13:00:29
0

以下是一个按年份查询学生注册课程的查询的示例代码解决方法(使用Python和MySQL数据库):

  1. 创建数据库表格和插入数据:
import mysql.connector

# 创建数据库连接
db = mysql.connector.connect(
    host="localhost",
    user="yourusername",
    password="yourpassword",
    database="yourdatabase"
)

# 创建游标对象
cursor = db.cursor()

# 创建学生表格
cursor.execute("CREATE TABLE students (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255))")

# 创建课程表格
cursor.execute("CREATE TABLE courses (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255), year INT)")

# 创建学生注册课程表格
cursor.execute("CREATE TABLE student_courses (student_id INT, course_id INT, FOREIGN KEY(student_id) REFERENCES students(id), FOREIGN KEY(course_id) REFERENCES courses(id))")

# 插入示例数据
cursor.execute("INSERT INTO students (name) VALUES ('Alice')")
cursor.execute("INSERT INTO students (name) VALUES ('Bob')")
cursor.execute("INSERT INTO students (name) VALUES ('Charlie')")

cursor.execute("INSERT INTO courses (name, year) VALUES ('Math', 2021)")
cursor.execute("INSERT INTO courses (name, year) VALUES ('Science', 2021)")
cursor.execute("INSERT INTO courses (name, year) VALUES ('English', 2020)")

cursor.execute("INSERT INTO student_courses (student_id, course_id) VALUES (1, 1)")
cursor.execute("INSERT INTO student_courses (student_id, course_id) VALUES (2, 1)")
cursor.execute("INSERT INTO student_courses (student_id, course_id) VALUES (3, 2)")

# 提交数据库操作
db.commit()
  1. 查询按年份查询学生注册课程:
import mysql.connector

# 创建数据库连接
db = mysql.connector.connect(
    host="localhost",
    user="yourusername",
    password="yourpassword",
    database="yourdatabase"
)

# 创建游标对象
cursor = db.cursor()

# 获取用户输入的年份
year = input("请输入要查询的年份:")

# 查询学生注册课程
cursor.execute("SELECT students.name, courses.name FROM students JOIN student_courses ON students.id = student_courses.student_id JOIN courses ON courses.id = student_courses.course_id WHERE courses.year = %s", (year,))

# 获取查询结果
results = cursor.fetchall()

# 打印查询结果
for result in results:
    print("学生姓名:", result[0])
    print("课程名称:", result[1])
    print("----------------------")

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

上述代码中,我们首先创建了一个包含三个表格的数据库:学生表格(students)、课程表格(courses)和学生注册课程表格(student_courses)。然后,我们向这些表格插入了一些示例数据。

接下来,我们在查询代码中获取用户输入的年份,并使用该年份作为参数执行查询语句。查询语句使用了JOIN语句来连接学生表格、学生注册课程表格和课程表格,并通过WHERE子句来筛选特定年份的课程。最后,我们通过循环遍历查询结果并打印出来。

请注意,在使用这段代码前,你需要根据你的实际情况修改数据库连接参数(如主机名、用户名、密码和数据库名称)。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...