首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL - Subquery,从SELECT中选择

SQL - Subquery,从SELECT中选择
EN

Stack Overflow用户
提问于 2018-10-31 01:02:18
回答 1查看 113关注 0票数 0

我的数据库查询:

代码语言:javascript
复制
CREATE DATABASE [College Assignment]
PRINT 'CREATE DATABASE College Assignment'
GO
USE [College Assignment]

CREATE TABLE Departments
(DEPART nvarchar(255) NOT NULL, D_NAME nvarchar(255), HEAD  nvarchar(255),PRIMARY KEY (DEPART));

CREATE TABLE Courses
(COURSE_ID      nvarchar(255) NOT NULL,
COURSE_NAME     nvarchar(255),
"TYPE"          nvarchar(255),
POINTS          float,
DEPARTMENT_ID   nvarchar(255),
PRIMARY KEY     (COURSE_ID),
CONSTRAINT fk_dep
FOREIGN KEY (DEPARTMENT_ID) REFERENCES Departments(DEPART));

CREATE TABLE Students
(STUDENT_ID     float NOT NULL,
S_NAME          nvarchar(255),
CITY            nvarchar(255),
PRIMARY KEY (STUDENT_ID));

CREATE TABLE Grades
(STUDENT_ID     float NOT NULL,
COURSE_ID       nvarchar(255) NOT NULL,
SEMESTER        nvarchar(255),
TERM            nvarchar(255),
GRADE           smallint,
GRADE_SEM       smallint,
PRIMARY KEY (STUDENT_ID, COURSE_ID),
CONSTRAINT fk_student
FOREIGN KEY (STUDENT_ID) REFERENCES Students(STUDENT_ID),
CONSTRAINT fk_course
FOREIGN KEY (COURSE_ID) REFERENCES Courses(COURSE_ID));

INSERT INTO Departments VALUES
('BS','Buisnes','Dr.Eyal'),
('CH','Chemistry','Prof.Doron'),
('CS','Computer Science','Dr.Israel'),
('MT','Mathematics','Prof.Levi');

INSERT INTO Courses VALUES
('B-10','Marketing','CLASS',5,'BS'),
('B-40','Operations Res.','SEMIN',3,'BS'),
('C-200','Programing','LAB',4,'CS'),
('C-300','Pascal','LAB',4,'CS'),
('C-55','Data Base','CLASS',3,'CS'),
('M-100','Linear Algebra','CLASS',3,'MT'),
('M-200','Numeric Analyses','CLASS',3,'MT');

INSERT INTO Students VALUES
(105,'Moshe','Haifa'),
(107,'Eyal','Tel Aviv'),
(110,'Ran','Haifa'),
(200,'David','Tel Aviv'),
(210,'Dan','Tel Aviv'),
(240,'Ayelet','Tel Aviv'),
(245,'Yoel','Haifa'),
(310,'Tova','Jerusalem');

INSERT INTO Grades VALUES
(105,'B-40','WIN1999','B',70,70),
(105,'C-200','AUT1999','A',90,85),
(105,'C-55','SUM1998','A',58,70),
(105,'M-100','SUM1998','B',75,50),
(200,'B-10','AUT1999','A',70,65),
(200,'C-200','AUT1999','B',78,50),
(200,'M-100','SUM1998','B',90,90),
(210,'B-10','WIN1999','A',78,50),
(210,'C-200','AUT1999','A',85,80),
(210,'M-100','AUT1999','A',90,90),
(245,'B-10','AUT1999','A',80,70),
(245,'B-40','WIN1998','A',85,95),
(245,'M-100','AUT1999','A',90,80),
(310,'M-100','SUM1998','A',65,100);

现在我要做的是打印所有的课程名称和学生的名字,如果他们的成绩乘以1.1是大于学期成绩的。

现在,我通过打印course_idstudent_id来实现它,但是在这个结果上,我尝试连接student_id和它们的名称,以便实际打印学生名称(s_name)和课程名称,而不是(course_id)

这是我当前的脚本:

代码语言:javascript
复制
SELECT STUDENT_ID,COURSE_ID
FROM Grades
WHERE (Grade*1.1>GRADE_SEM)

基本上,我想要的结果和我得到的结果完全一样,但是学生名是(s_name)course_name,而不是他们的id's。(这是我现在得到的指纹

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-31 01:21:15

实际上,很简单,Join可以做到

代码语言:javascript
复制
SELECT 
     Students.S_Name, Courses.Course_Name,
     Students.Student_ID, Courses.Course_ID
FROM 
     Grades 
     INNER JOIN Students on Students.Student_ID = Grades.Student_ID
     INNER JOIN Courses on Courses.Course_ID = Grades.Course_ID
WHERE 
     (Grades.Grade*1.1>Grades.GRADE_SEM)

您可以在这里更多地阅读Joinhttps://learn.microsoft.com/en-us/sql/relational-databases/performance/joins?view=sql-server-2017

您可以在这里看到Demo = Demo

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53074855

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档