找出所有教师名字
1
select name from instructor;
找出所有教师系名
1
select dept_name from instructor;
找出所有不重复的系名
1
select distinct dept_name from instructor;
找出CS系并且工资超过7000的教师名字
1
select name from instructor where dept_name='CS' and salary>7000;
找出所有教师名字,以及他们所在系的建筑名字
1
select name,instructor.dept_name,building from instructor,department where instructor.dept_name=department.dept_name;
找出CS系的教师名和课程ID
1
select name,course_id from instructor,teaches where instructor.ID = teaches.ID and instructor.dept_name='CS';
找出教师的名字和他们所教课的ID
1
select name,course_id from instructor natural join teaches;
找出教师名字和他们所教课的名字
1
select name,title from instructor natural join teaches,course where teaches.course_id=course.course_id;
找出 “工资至少比Biology系某一个教师工资要高” 的所有教师名字
1
select distinct T.name from instructor as T, instructor as S where T.salary > S.salary and S.dept_name='Biology';
1
select name from instructor where salary > some(select salary from instructor where dept_name='Biology');
找出按字母排序在Biology的所有老师
1
select name from instructor where dept_name='Biology' order by name;
找出工资降序,如果工资相同姓名升序的教师
1
select name from instructor order by salary desc,name asc;
找出工资在9000到10000的教师
1
2select name from instructor where salary between 9000 and 10000;
select name from instructor where salary >= 9000 and salary <= 10000;
找出Biology系授课的所有教师名字和他们所教授的课程
1
select name,course_id from instructor, teaches where instructor.ID=teaches.ID and dept_name='Biology';
找出2009年秋季和2010年春季的所有的课程
1
(select course_id from section where semester='Fall' and year=2009) union (select course_id from section where semester='Spring' and year=2010) ;
1
找出2009年秋季和2010年春季的同时开课的课程
1
select distinct course_id from section where semester='Spring' and year=2009 and course_id in(select course_id from section where semester='Spring' and year=2010);
1
select course_id from section as S where semester='Fall' and year=2009 and exists(select * from section as T where semester='Spring' and year=2010 and S.course_id=T.course_id);
找出在2009年秋季开课和不在2010年春季开课的课程
1
select distinct course_id from section where semester='Spring' and year=2009 and course_id not in(select course_id from section where semester='Spring' and year=2010);
找出CS系教师平均工资
1
select avg(salary) from instructor where dept_name='CS';
找出2010春季讲授课程的教师总数
1
select count(distinct ID) from teaches where semester='Spring' and year=2010;
找出每个系的平均工资
1
select dept_name,avg(salary) from instructor group by dept_name;
找出所有老师的平均工资
1
select avg(salary) from instructor;
找出每个系在2010年春季讲授一门课程的教师人数
1
2
3
4
5
6
7
8
9SELECT
dept_name, COUNT(DISTINCT ID)
FROM
instructor
NATURAL JOIN
teaches
WHERE
semester = 'Spring' AND year = 2010
GROUP BY dept_name;
找出教师平均工资超过42000美元的系
1
2
3
4
5
6SELECT
dept_name, AVG(salary)
FROM
instructor
GROUP BY dept_name
HAVING AVG(salary) > 42000;
找出2009年讲授的每个课程段,如果该课程段至少两名学生选课,找出选修该课程段的所有学生总学分的平均值
1
2
3
4
5
6
7
8
9
10SELECT
course_id, semester, year, sec_id, AVG(tot_cred)
FROM
takes
NATURAL JOIN
student
WHERE
year = 2009
GROUP BY course_id , semester , year , sec_id
HAVING COUNT(ID) >= 2;
找出既不叫Bob也不叫Ali的教师名字
1
select distinct name from instructor where name not in('Bob','Ali')
找出不同的学生总数,选修ID为10101教师所教授的课程段
1
2
3
4
5
6
7
8
9
10
11SELECT
COUNT(DISTINCT ID)
FROM
takes
WHERE
(course_id , sec_id, year) IN (SELECT
course_id, sec_id, year
FROM
teaches
WHERE
teaches.ID = 10101);
找出 “工资比Biology系所有教师工资要高” 的所有教师名字
1
select name from instructor where salary > all(select salary from instructor where dept_name='Biology');
找出平均工资大于所有系平均工资的系
1
select dept_name from instructor group by dept_name having avg(salary) >= all(select avg(salary) from instructor group by dept_name);
找出选修了Biology系所开设的所有课程的学生
找出所有在2009年最多开设一次的课程
找出所有在2009年最少开设两次的课程
找出系平均工资超过42000美元的那些系中的教师平均工资
所有系工资总额最大系
所有系和他们拥有的教师数
删除工作在Watson大楼系工作的教师
删除平均工资低于大学平均工资的教师
让CS系修满144学分的学生成为CS系的老师,并且其平均工资为8000
工资低于1000教师工资增加5%
工资低于平均数的教师工资增加5%
工资超过1000教师涨5%,其余增长8%
一个学生在某门课成绩既不是F,也不是空,认为修完了该课程
找出所有课程一门也没选修的学生
找出CS系所有学生以及他们在2009年春季选修的所有课程
其他联系平台