logo资料库

数据库系统概念 大学数据库完整模式 mysql版.docx

第1页 / 共8页
第2页 / 共8页
第3页 / 共8页
第4页 / 共8页
第5页 / 共8页
第6页 / 共8页
第7页 / 共8页
第8页 / 共8页
资料共8页,全文预览结束
-- 数据库系统概念 大学数据库完整模式 MySQL 版 -- https://altli.blog.csdn.net/ 2020/03/04 create database University; use University; -- classroom 表存放上课教室的信息 -- 包括:教室所在教学楼、教室号、教室最大学生数量 -- 主码:教室所在教学楼、教室号 create table classroom ( building varchar(15), room_number varchar(7), capacity numeric(4, 0), primary key(building, room_number) ); -- department 表存放某系的信息 -- 包括:系名、系所在教学楼、年预算 -- 主码:系名 create table department ( dept_name varchar(20), building varchar(15), budget numeric(12,2) check(budget > 0), primary key(dept_name) ); -- course 表存放了有关课程的信息 -- 包括:课程 ID、课程名、系名、学分 -- 主码:课程 ID create table course ( course_id varchar(8), title varchar(50), dept_name varchar(20), credits numeric(2,0) check(credits > 0), primary key(course_id), foreign key(dept_name) references department(dept_name) on delete set null ); -- instructor 表存放了有关教师的信息 -- 包括:教师 ID、姓名、系名、年薪 -- 主码:教师 ID
create table instructor ( ID varchar(5), name varchar(20) not null, dept_name varchar(20), salary numeric(8,2) check(salary > 29000), primary key(ID), foreign key(dept_name) references department(dept_name) on delete set null ); -- section 表存放了课程具体的授课情况 -- 包括:课程 ID、课程段 ID、学期、年、教学楼、教室号、课程节次 -- 主码:课程 ID、课程段 ID、学期、年 create table section ( course_id varchar(8), sec_id varchar(8), semester varchar(6) check(semester in ('Fall','Winter', 'Spring','Summer')), year numeric(4,0) check(year > 1701 and year < 2100), building varchar(15), room_number varchar(7), time_slot_id varchar(4), primary key(course_id, sec_id, semester, year), foreign key(course_id) references course(course_id) foreign key(building, room_number) references classroom(building, room_number) on delete cascade, on delete set null ); -- teaches 表存放了有关教师授课的信息 -- 包括:教师 ID、课程 ID、课程段 ID、学期、年 -- 主码:教师 ID、课程 ID、课程段 ID、学期、年 create table teaches ( ID varchar(5), course_id varchar(8), sec_id varchar(8), semester varchar(6), year numeric(4, 0), primary key(ID, course_id, sec_id, semester, year), foreign key(course_id, sec_id, semester, year) references section(course_id, sec_id, semester, year) on delete cascade,
foreign key(ID) references instructor(ID) on delete cascade -- student 表存放了有关学生的信息 -- 包括:学生 ID、学生姓名、系名、总绩点 -- 主码:学生 ID create table student ( ID varchar(5), name varchar(20) not null, dept_name varchar(20), tot_cred numeric(3, 0) check(tot_cred >= 0), primary key(ID), foreign key(dept_name) references department(dept_name) on delete set null ); ); ); -- takes 表存放了有关学生每门课程的信息 -- 包括:学生 ID、课程 ID、课程段 ID、学期、年、分数 -- 主码:学生 ID、课程 ID、课程段 ID、学期、年 create table takes ( ID varchar(5), course_id varchar(8), sec_id varchar(8), semester varchar(6), year numeric(4, 0), grade varchar(2), primary key(ID, course_id, sec_id, semester, year), foreign key(ID) references student(ID) on delete cascade -- advisor 表存放了有关学生导师的信息 -- 包括:学生 ID、教师 ID -- 主码:学生 ID create table advisor ( s_ID varchar(5), i_ID varchar(5), primary key(s_ID), foreign key(i_ID) references instructor(ID) on delete set null,
foreign key(s_ID) references student(ID) on delete cascade ); -- prereq 表存放每门课程的先修课程信息 -- 包括:当前课程 ID、先修课程 ID -- 主码:当前课程 ID、先修课程 ID create table prereq ( course_id varchar(8), prereq_id varchar(8), primary key(course_id, prereq_id), foreign key(course_id) references course(course_id) on delete cascade, foreign key(prereq_id) references course(course_id) ); -- time_slot 表存放了课程上课时间的信息 -- 包括:课程节次、课程上课星期、开始时间(小时)、开始时间(分钟)、结 束时间(小时)、结束时间(分钟) -- 主码:课程节次、课程上课星期、开始时间(小时)、开始时间(分钟) create table time_slot ( time_slot_id varchar(4), day varchar(1), start_hr numeric(2) check (start_hr >= 0 and end_hr < 24), start_min numeric(2) check (start_min >= 0 and start_min < 60), end_hr numeric(2) check (end_hr >= 0 and end_hr < 24), end_min numeric(2) check (end_min >= 0 and end_min < 60), primary key(time_slot_id, day, start_hr, start_min) ); insert into classroom values ('Packard', '101', '500'); insert into classroom values ('Painter', '514', '10'); insert into classroom values ('Taylor', '3128', '70'); insert into classroom values ('Watson', '100', '30'); insert into classroom values ('Watson', '120', '50'); insert into department values ('Biology', 'Watson', '90000'); insert into department values ('Comp. Sci.', 'Taylor', '100000'); insert into department values ('Elec. Eng.', 'Taylor', '85000'); insert into department values ('Finance', 'Painter', '120000'); insert into department values ('History', 'Painter', '50000'); insert into department values ('Music', 'Packard', '80000'); insert into department values ('Physics', 'Watson', '70000');
insert into course values ('BIO-101', 'Intro. to Biology', 'Biology', '4'); insert into course values ('BIO-301', 'Genetics', 'Biology', '4'); insert into course values ('BIO-399', 'Computational Biology', 'Biology', '3'); insert into course values ('CS-101', 'Intro. to Computer Science', 'Comp. Sci.', '4'); insert into course values ('CS-190', 'Game Design', 'Comp. Sci.', '4'); insert into course values ('CS-315', 'Robotics', 'Comp. Sci.', '3'); insert into course values ('CS-319', 'Image Processing', 'Comp. Sci.', '3'); insert into course values ('CS-347', 'Database System Concepts', 'Comp. Sci.', '3'); insert into course values ('EE-181', 'Intro. to Digital Systems', 'Elec. Eng.', '3'); insert into course values ('FIN-201', 'Investment Banking', 'Finance', '3'); insert into course values ('HIS-351', 'World History', 'History', '3'); insert into course values ('MU-199', 'Music Video Production', 'Music', '3'); insert into course values ('PHY-101', 'Physical Principles', 'Physics', '4'); insert into instructor values ('10101', 'Srinivasan', 'Comp. Sci.', '65000'); insert into instructor values ('12121', 'Wu', 'Finance', '90000'); insert into instructor values ('15151', 'Mozart', 'Music', '40000'); insert into instructor values ('22222', 'Einstein', 'Physics', '95000'); insert into instructor values ('32343', 'El Said', 'History', '60000'); insert into instructor values ('33456', 'Gold', 'Physics', '87000'); insert into instructor values ('45565', 'Katz', 'Comp. Sci.', '75000'); insert into instructor values ('58583', 'Califieri', 'History', '62000'); insert into instructor values ('76543', 'Singh', 'Finance', '80000'); insert into instructor values ('76766', 'Crick', 'Biology', '72000'); insert into instructor values ('83821', 'Brandt', 'Comp. Sci.', '92000'); insert into instructor values ('98345', 'Kim', 'Elec. Eng.', '80000'); insert into section values ('BIO-101', '1', 'Summer', '2009', 'Painter', '514', 'B'); insert into section values ('BIO-301', '1', 'Summer', '2010', 'Painter', '514', 'A'); insert into section values ('CS-101', '1', 'Fall', '2009', 'Packard', '101', 'H'); insert into section values ('CS-101', '1', 'Spring', '2010', 'Packard', '101', 'F'); insert into section values ('CS-190', '1', 'Spring', '2009', 'Taylor', '3128', 'E'); insert into section values ('CS-190', '2', 'Spring', '2009', 'Taylor', '3128', 'A'); insert into section values ('CS-315', '1', 'Spring', '2010', 'Watson', '120', 'D'); insert into section values ('CS-319', '1', 'Spring', '2010', 'Watson', '100', 'B'); insert into section values ('CS-319', '2', 'Spring', '2010', 'Taylor', '3128', 'C'); insert into section values ('CS-347', '1', 'Fall', '2009', 'Taylor', '3128', 'A'); insert into section values ('EE-181', '1', 'Spring', '2009', 'Taylor', '3128', 'C'); insert into section values ('FIN-201', '1', 'Spring', '2010', 'Packard', '101', 'B'); insert into section values ('HIS-351', '1', 'Spring', '2010', 'Painter', '514', 'C'); insert into section values ('MU-199', '1', 'Spring', '2010', 'Packard', '101', 'D'); insert into section values ('PHY-101', '1', 'Fall', '2009', 'Watson', '100', 'A');
insert into teaches values ('10101', 'CS-101', '1', 'Fall', '2009'); insert into teaches values ('10101', 'CS-315', '1', 'Spring', '2010'); insert into teaches values ('10101', 'CS-347', '1', 'Fall', '2009'); insert into teaches values ('12121', 'FIN-201', '1', 'Spring', '2010'); insert into teaches values ('15151', 'MU-199', '1', 'Spring', '2010'); insert into teaches values ('22222', 'PHY-101', '1', 'Fall', '2009'); insert into teaches values ('32343', 'HIS-351', '1', 'Spring', '2010'); insert into teaches values ('45565', 'CS-101', '1', 'Spring', '2010'); insert into teaches values ('45565', 'CS-319', '1', 'Spring', '2010'); insert into teaches values ('76766', 'BIO-101', '1', 'Summer', '2009'); insert into teaches values ('76766', 'BIO-301', '1', 'Summer', '2010'); insert into teaches values ('83821', 'CS-190', '1', 'Spring', '2009'); insert into teaches values ('83821', 'CS-190', '2', 'Spring', '2009'); insert into teaches values ('83821', 'CS-319', '2', 'Spring', '2010'); insert into teaches values ('98345', 'EE-181', '1', 'Spring', '2009'); insert into student values ('00128', 'Zhang', 'Comp. Sci.', '102'); insert into student values ('12345', 'Shankar', 'Comp. Sci.', '32'); insert into student values ('19991', 'Brandt', 'History', '80'); insert into student values ('23121', 'Chavez', 'Finance', '110'); insert into student values ('44553', 'Peltier', 'Physics', '56'); insert into student values ('45678', 'Levy', 'Physics', '46'); insert into student values ('54321', 'Williams', 'Comp. Sci.', '54'); insert into student values ('55739', 'Sanchez', 'Music', '38'); insert into student values ('70557', 'Snow', 'Physics', '0'); insert into student values ('76543', 'Brown', 'Comp. Sci.', '58'); insert into student values ('76653', 'Aoi', 'Elec. Eng.', '60'); insert into student values ('98765', 'Bourikas', 'Elec. Eng.', '98'); insert into student values ('98988', 'Tanaka', 'Biology', '120'); insert into takes values ('00128', 'CS-101', '1', 'Fall', '2009', 'A'); insert into takes values ('00128', 'CS-347', '1', 'Fall', '2009', 'A-'); insert into takes values ('12345', 'CS-101', '1', 'Fall', '2009', 'C'); insert into takes values ('12345', 'CS-190', '2', 'Spring', '2009', 'A'); insert into takes values ('12345', 'CS-315', '1', 'Spring', '2010', 'A'); insert into takes values ('12345', 'CS-347', '1', 'Fall', '2009', 'A'); insert into takes values ('19991', 'HIS-351', '1', 'Spring', '2010', 'B'); insert into takes values ('23121', 'FIN-201', '1', 'Spring', '2010', 'C+'); insert into takes values ('44553', 'PHY-101', '1', 'Fall', '2009', 'B-'); insert into takes values ('45678', 'CS-101', '1', 'Fall', '2009', 'F'); insert into takes values ('45678', 'CS-101', '1', 'Spring', '2010', 'B+'); insert into takes values ('45678', 'CS-319', '1', 'Spring', '2010', 'B'); insert into takes values ('54321', 'CS-101', '1', 'Fall', '2009', 'A-'); insert into takes values ('54321', 'CS-190', '2', 'Spring', '2009', 'B+');
insert into takes values ('55739', 'MU-199', '1', 'Spring', '2010', 'A-'); insert into takes values ('76543', 'CS-101', '1', 'Fall', '2009', 'A'); insert into takes values ('76543', 'CS-319', '2', 'Spring', '2010', 'A'); insert into takes values ('76653', 'EE-181', '1', 'Spring', '2009', 'C'); insert into takes values ('98765', 'CS-101', '1', 'Fall', '2009', 'C-'); insert into takes values ('98765', 'CS-315', '1', 'Spring', '2010', 'B'); insert into takes values ('98988', 'BIO-101', '1', 'Summer', '2009', 'A'); insert into takes values ('98988', 'BIO-301', '1', 'Summer', '2010', null); insert into advisor values ('00128', '45565'); insert into advisor values ('12345', '10101'); insert into advisor values ('23121', '76543'); insert into advisor values ('44553', '22222'); insert into advisor values ('45678', '22222'); insert into advisor values ('76543', '45565'); insert into advisor values ('76653', '98345'); insert into advisor values ('98765', '98345'); insert into advisor values ('98988', '76766'); insert into time_slot values ('A', 'M', '8', '0', '8', '50'); insert into time_slot values ('A', 'W', '8', '0', '8', '50'); insert into time_slot values ('A', 'F', '8', '0', '8', '50'); insert into time_slot values ('B', 'M', '9', '0', '9', '50'); insert into time_slot values ('B', 'W', '9', '0', '9', '50'); insert into time_slot values ('B', 'F', '9', '0', '9', '50'); insert into time_slot values ('C', 'M', '11', '0', '11', '50'); insert into time_slot values ('C', 'W', '11', '0', '11', '50'); insert into time_slot values ('C', 'F', '11', '0', '11', '50'); insert into time_slot values ('D', 'M', '13', '0', '13', '50'); insert into time_slot values ('D', 'W', '13', '0', '13', '50'); insert into time_slot values ('D', 'F', '13', '0', '13', '50'); insert into time_slot values ('E', 'T', '10', '30', '11', '45 '); insert into time_slot values ('E', 'R', '10', '30', '11', '45 '); insert into time_slot values ('F', 'T', '14', '30', '15', '45 '); insert into time_slot values ('F', 'R', '14', '30', '15', '45 '); insert into time_slot values ('G', 'M', '16', '0', '16', '50'); insert into time_slot values ('G', 'W', '16', '0', '16', '50'); insert into time_slot values ('G', 'F', '16', '0', '16', '50'); insert into time_slot values ('H', 'W', '10', '0', '12', '30'); insert into prereq values ('BIO-301', 'BIO-101'); insert into prereq values ('BIO-399', 'BIO-101'); insert into prereq values ('CS-190', 'CS-101'); insert into prereq values ('CS-315', 'CS-101');
insert into prereq values ('CS-319', 'CS-101'); insert into prereq values ('CS-347', 'CS-101'); insert into prereq values ('EE-181', 'PHY-101');
分享到:
收藏