用sql1. 创建下列关系表:4)DEPARTMENT表(系部表) 字段名 字段说明 字段类型 是否允许为空 DEPT_NO 系部编号 字符串 否 DEPT_NAME 系部名称 字符串 否 主键:DEPT_NO (5)STUDENT表(学生表) 字段说明: 字段名 字段说明 字段类型 是否允许为空 S_NO 学号 字符串 否 S_NAME 学生姓名 字符串 否 S_SEX 性别 字符串 否 S_BIRTHDAY 出生日期 日期 是 S_SCORE 入学总分 整数 是 S_ADDF 入学附加分 整数 是 CLASS_NO 所在班级编号 字符串 否 主键:S_NO
时间: 2023-12-17 08:05:41 浏览: 88
好的,以下是创建DEPARTMENT表和STUDENT表的SQL语句:
CREATE TABLE DEPARTMENT (
DEPT_NO VARCHAR(20) NOT NULL PRIMARY KEY,
DEPT_NAME VARCHAR(50) NOT NULL
);
CREATE TABLE STUDENT (
S_NO VARCHAR(20) NOT NULL PRIMARY KEY,
S_NAME VARCHAR(50) NOT NULL,
S_SEX VARCHAR(10) NOT NULL,
S_BIRTHDAY DATE,
S_SCORE INT,
S_ADDF INT,
CLASS_NO VARCHAR(20) NOT NULL
);
注意,这里指定了DEPT_NO和S_NO为主键,因此不允许出现重复的值。同时,所有字段都不允许为空,除了S_BIRTHDAY,S_SCORE和S_ADDF。S_BIRTHDAY为日期类型,S_SCORE和S_ADDF为整数类型。CLASS_NO为学生所在班级的编号,不允许为空。
相关问题
按t_student(学生表)、t_course(课程表)、t_scores(选课成绩表)、t_class(班级表)。学生信息表( t_student) 字段名 名称 数据类型 空 备注 SNo 学号 Char(20) N 主键 Sname 姓名 varchar(50) N Sex 性别 Char(2) Y class_name 班级名 Char(2) Y 2.课程表 课程表( t_course) 字段名 名称 数据类型 空 备注 CNo 课程编号 Char(10) N 主键 Cname 课程名称 varchar(50) N Credit 学分 Int Y 3.选课表 选课成绩表(scores) 字段名 名称 数据类型 空 备注 SNo 学号 Char(20) N 主键 CNo 课程号 Char(10) N 主键 grade 成绩 Int Y 4.班级表 班级表(t_class) 字段名 名称 数据类型 空 备注 class_name 部门编号 Char(2) N 主键 department 部门名称 varChar(50) N teacher 教师 varChar(20) classroom 教室 varChar(30)说明在你创建的数据库下创建四个表格: t_student(学生表)、t_course(课程表)、t_scores(选课成绩表)、t_class(班级表)。要求: (1)表名和列名必须用英文名称即附件中提供的表名和字段名。不满足此要求每个表扣2分。 (2)每个表要设置主键。没设置主键每个表扣1分。 (3)给学生表中的sex字段定义一个check约束(取值只能是‘男’ 或 ‘女’)。定义学生表的class_name字段与班级表的class_name字段为外键关系。没按要求定义约束每个扣1分。
好的,你的问题是如何在 MySQL 中创建这四个表格并满足要求?
以下是创建这四个表格的 SQL 语句,已满足要求:
1. 学生表 t_student:
```sql
CREATE TABLE t_student (
SNo CHAR(20) NOT NULL PRIMARY KEY,
Sname VARCHAR(50) NOT NULL,
Sex CHAR(2) DEFAULT NULL CHECK(Sex IN ('男', '女')),
class_name CHAR(2) DEFAULT NULL,
CONSTRAINT fk_class_name FOREIGN KEY (class_name) REFERENCES t_class (class_name)
);
```
2. 课程表 t_course:
```sql
CREATE TABLE t_course (
CNo CHAR(10) NOT NULL PRIMARY KEY,
Cname VARCHAR(50) NOT NULL,
Credit INT DEFAULT NULL
);
```
3. 选课成绩表 t_scores:
```sql
CREATE TABLE t_scores (
SNo CHAR(20) NOT NULL,
CNo CHAR(10) NOT NULL,
grade INT DEFAULT NULL,
PRIMARY KEY (SNo, CNo),
CONSTRAINT fk_SNo FOREIGN KEY (SNo) REFERENCES t_student (SNo),
CONSTRAINT fk_CNo FOREIGN KEY (CNo) REFERENCES t_course (CNo)
);
```
4. 班级表 t_class:
```sql
CREATE TABLE t_class (
class_name CHAR(2) NOT NULL PRIMARY KEY,
department VARCHAR(50) NOT NULL,
teacher VARCHAR(20) DEFAULT NULL,
classroom VARCHAR(30) DEFAULT NULL
);
```
以上是创建这四个表格的 SQL 语句,并满足了要求。
按附件(数据字典)说明在你创建的数据库下创建四个表格: t_student(学生表)、t_course(课程表)、t_scores(选课成绩表)、t_class(班级表)。学生信息表( t_student) 字段名 名称 数据类型 空 备注 SNo 学号 Char(20) N 主键 Sname 姓名 varchar(50) N Sex 性别 Char(2) Y class_name 班级名 Char(2) Y 2.课程表 课程表( t_course) 字段名 名称 数据类型 空 备注 CNo 课程编号 Char(10) N 主键 Cname 课程名称 varchar(50) N Credit 学分 Int Y 3.选课表 选课成绩表(scores) 字段名 名称 数据类型 空 备注 SNo 学号 Char(20) N 主键 CNo 课程号 Char(10) N 主键 grade 成绩 Int Y 4.班级表 班级表(t_class) 字段名 名称 数据类型 空 备注 class_name 部门编号 Char(2) N 主键 department 部门名称 varChar(50) N teacher 教师 varChar(20) classroom 教室 varChar(30)
根据数据字典,可以使用以下 SQL 语句在创建的数据库中创建四个表:
```sql
-- 创建学生表
CREATE TABLE t_student (
SNo CHAR(20) NOT NULL PRIMARY KEY COMMENT '学号',
Sname VARCHAR(50) NOT NULL COMMENT '姓名',
Sex CHAR(2) COMMENT '性别',
class_name CHAR(2) COMMENT '班级名',
FOREIGN KEY (class_name) REFERENCES t_class(class_name)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
-- 创建课程表
CREATE TABLE t_course (
CNo CHAR(10) NOT NULL PRIMARY KEY COMMENT '课程编号',
Cname VARCHAR(50) NOT NULL COMMENT '课程名称',
Credit INT COMMENT '学分'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
-- 创建选课成绩表
CREATE TABLE t_scores (
SNo CHAR(20) NOT NULL COMMENT '学号',
CNo CHAR(10) NOT NULL COMMENT '课程号',
grade INT COMMENT '成绩',
PRIMARY KEY (SNo, CNo),
FOREIGN KEY (SNo) REFERENCES t_student(SNo),
FOREIGN KEY (CNo) REFERENCES t_course(CNo)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
-- 创建班级表
CREATE TABLE t_class (
class_name CHAR(2) NOT NULL PRIMARY KEY COMMENT '部门编号',
department VARCHAR(50) NOT NULL COMMENT '部门名称',
teacher VARCHAR(20) COMMENT '教师',
classroom VARCHAR(30) COMMENT '教室'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
```
说明:
1. 表名和列名都采用了英文名称,符合要求。
2. 每个表都设置了主键,符合要求。
3. 学生表中的 sex 字段和选课成绩表中的 grade 字段都设置了数据类型,符合要求。
4. 学生表的 class_name 字段和选课成绩表的 SNo 和 CNo 字段都设置了外键约束,参照了班级表的 class_name 字段和课程表的 CNo 字段,符合要求。
5. 课程表添加了 Credit 字段,符合要求。
6. 班级表中的 teacher 和 classroom 字段都没有设置为 NOT NULL,因为数据字典中没有要求,但是仍然按照规范进行了定义。
阅读全文