mysql创建学生,课程,sc表
时间: 2023-05-23 22:02:58 浏览: 312
好的,以下是创建学生、课程和sc表的MySQL代码:
--创建学生表
CREATE TABLE student (
stud_id INT(11) NOT NULL AUTO_INCREMENT,
name VARCHAR(50) NOT NULL,
gender CHAR(1) NOT NULL,
dob DATE NOT NULL,
PRIMARY KEY (stud_id)
);
--创建课程表
CREATE TABLE course (
course_id INT(11) NOT NULL AUTO_INCREMENT,
title VARCHAR(50) NOT NULL,
PRIMARY KEY (course_id)
);
--创建选课表
CREATE TABLE sc (
stud_id INT(11) NOT NULL,
course_id INT(11) NOT NULL,
score INT(11),
PRIMARY KEY (stud_id, course_id),
FOREIGN KEY (stud_id) REFERENCES student(stud_id),
FOREIGN KEY (course_id) REFERENCES course(course_id)
);
希望这能帮助您!
相关问题
创建student,course,sc表
可以使用 SQL 语句来创建 student, course, sc 表。
student 表示学生信息,可以有字段:ID(学号)、Name(姓名)、Gender(性别)、Age(年龄)等。
course 表示课程信息,可以有字段:ID(课程号)、Name(课程名称)、Credit(学分)等。
sc 表示学生选课信息,可以有字段:StudentID(学号)、CourseID(课程号)、Grade(成绩)等。
示例 SQL 语句如下:
```
CREATE TABLE student (
ID INT PRIMARY KEY,
Name VARCHAR(20),
Gender CHAR(1),
Age INT
);
CREATE TABLE course (
ID INT PRIMARY KEY,
Name VARCHAR(20),
Credit INT
);
CREATE TABLE sc (
StudentID INT,
CourseID INT,
Grade INT,
PRIMARY KEY (StudentID, CourseID),
FOREIGN KEY (StudentID) REFERENCES student(ID),
FOREIGN KEY (CourseID) REFERENCES course(ID)
);
```
注意:上面的 SQL 语句是根据 MySQL 的语法,如果使用其他数据库管理系统可能会有所不同。
MySQL中如何创建学生成绩单视图
在MySQL中创建学生成绩单视图需要以下步骤:
1. 创建学生表和成绩表,包括学生ID、姓名、课程ID、成绩等字段。
2. 使用SELECT语句查询两个表,将学生表和成绩表进行JOIN操作,按照学生ID和课程ID进行关联,得到学生的成绩信息。
3. 使用GROUP BY语句对学生ID和姓名进行分组,计算每个学生的平均成绩。
4. 使用CREATE VIEW语句创建视图,将以上查询结果作为视图的内容。
以下是示例代码:
```sql
-- 创建学生表
CREATE TABLE students (
id INT PRIMARY KEY,
name VARCHAR(20)
);
-- 创建成绩表
CREATE TABLE scores (
id INT PRIMARY KEY,
student_id INT,
course_id INT,
score INT
);
-- 插入数据
INSERT INTO students VALUES (1, '张三');
INSERT INTO students VALUES (2, '李四');
INSERT INTO scores VALUES (1, 1, 1, 80);
INSERT INTO scores VALUES (2, 1, 2, 90);
INSERT INTO scores VALUES (3, 2, 1, 85);
INSERT INTO scores VALUES (4, 2, 2, 95);
-- 创建学生成绩单视图
CREATE VIEW student_scores AS
SELECT s.id AS student_id, s.name, c.course_id, AVG(sc.score) AS avg_score
FROM students s
JOIN scores sc ON s.id = sc.student_id
JOIN courses c ON sc.course_id = c.id
GROUP BY s.id, c.course_id;
```
以上代码中,我们创建了一个名为student_scores的视图,该视图包含了每个学生每门课程的平均成绩。你可以根据自己的实际需求调整查询语句和视图结构。