Объедините несвязанные таблицы в краткой форме - PullRequest
0 голосов
/ 30 октября 2018

Мне трудно подвести итоги таблицы SQL.

Objective: from the given tables I have to join and summarize the table.
col1 = Name_of_student, 
col2 = Name_of_subject(where she/he scored highest), 
col3= highest_number, 
col4 = faculty_Name(where she/he scored highest),
col5 = Name_of_subject(where she/he scored lowest), 
col6 = lowest marks, 
col7 = faculty_Name(where she/he scored lowest)

Примечание - мне нужно написать только один запрос для данного вывода.

Там четыре таблицы:

  1. Студенты.
  2. Students_subject.
  3. Факультет.
  4. Marks.

Вы можете скопировать код в моем скрипте SQL для понимания таблиц.

 create database university ;
    use university ;

    create table students (id int auto_increment primary key,
    student_name varchar(250) NOT NULL, 
    dob DATE NOT NULL) ;

    create table faculty ( id int auto_increment primary key,
    faculty_name varchar(250) NOT NULL,
    date_of_update datetime default NOW()) ;


     create table Students_subject ( id int auto_increment primary key,
     subject_name varchar(250) default 'unknown' NOT NULL,
     subject_faculty int not null,
     foreign key(subject_faculty) references faculty(id));

    create table marks (id int auto_increment primary key,
    student_id int NOT NULL,
    subject_id int NOT NULL,
    marks int NOT NULL,
    date_of_update datetime default now() ON UPDATE NOW(),
    foreign key(student_id) references students(id),
    foreign key(subject_id) references students_subject(id));

    insert into students ( student_name, dob) values 
    ('rob', '2001-03-06'),
    ('bbb', '2001-09-06'),
    ('rab', '1991-03-06'),
    ('root', '2001-03-16') ;


    insert into faculty(faculty_name) values
    ('kaka'),
    ('dope'),
    ('kallie'),
    ('kim');

    insert into students_subject (subject_name, subject_faculty) values
    ('maths', 2),
    ('physics', 3),
    ('english', 4),
    ('biology', 1),
    ('statistics', 2),
    ('french', 4),
    ('economics',3);


    insert into marks ( student_id, subject_id, marks) values
    (1,1,70),
    (1,2,60),
    (1,3,98),
    (1,4,75),
    (1,5,90),
    (1,6,30),
    (1,7,40),
    (2,1,70),
    (2,2,60),
    (2,3,70),
    (2,4,105),
    (2,5,95),
    (2,6,30),
    (2,7,10),
    (3,1,70),
    (3,2,60),
    (3,3,70),
    (3,4,75),
    (3,5,99),
    (3,6,30),
    (3,7,10),
    (4,1,70),
    (4,2,60),
    (4,3,70),
    (4,4,89),
    (4,5,99),
    (4,6,30),
    (4,7,19); 

Я сам написал Query, чтобы разобраться с этим, но не могу его сломать.

select students.id, table_high.marks, table_high.faculty_name as high_faculty, table_high.subject_name as sub_high,
student_low.marks , student_low.faculty_name as faculty_low, student_low.subject_name as sub_low from students
inner join
(select students.id, students.student_name ,marks.marks, subject_joined.faculty_name, students_subject.subject_name from marks
inner join (select  students_subject.id,students_subject.subject_name, faculty.faculty_name, students_subject.subject_faculty
from students_subject left join faculty on students_subject.subject_faculty = faculty.id)
as subject_joined on subject_joined.id = marks.subject_id
inner join faculty on subject_joined.subject_faculty = faculty.id
inner join students_subject on students_subject.id = marks.subject_id
inner join students on students.id = marks.student_id 
order by 1, 3 desc) as table_high on table_high.id = students.id
inner join 
(select students.id, students.student_name ,marks.marks, subject_joined.faculty_name, students_subject.subject_name from marks
inner join (select  students_subject.id,students_subject.subject_name, faculty.faculty_name, students_subject.subject_faculty
from students_subject left join faculty on students_subject.subject_faculty = faculty.id)
as subject_joined on subject_joined.id = marks.subject_id
inner join faculty on subject_joined.subject_faculty = faculty.id
inner join students_subject on students_subject.id = marks.subject_id
inner join students on students.id = marks.student_id 
order by 1, 3 ) as student_low on student_low.id = students.id
group by 1 ;

прикрепление экрана вывода:

Screen shot

1 Ответ

0 голосов
/ 03 ноября 2018

Наконец-то решили этот вопрос!

Базовая настройка, которая требовалась при обобщении этой таблицы, заключалась в том, что подтаблицу нужно было объединить с помощью комбинации из двух столбцов, так как группа по команде просто отражает значение первой строки в обобщенной таблице для не суммированных столбцов, поэтому Отражение значений max и min было невозможно в одно и то же время, для чего я создал вложенные таблицы, фильтруя строки с помощью двойных объединений столбцов, и, наконец, соединил таблицу с основной таблицей учеников.

Основной стол, к которому присоединились, это студенты.

Подтаблица 1 - hw (которая суммировала данные для самых высоких) Подтаблица 1.2 - максимум для мечения самых высоких оценок. Подстолье 2 - lw (который суммировал таблицу для самых низких) вложенная таблица 2.1 - низкий уровень для минимальной маркировки меток.

Запрос >>

select students.id, students.student_name, lw.min_marks, lw.lower_subject, lw.lower_faculty, 
hw.high_marks, hw.subject_name as high_subject, hw.faculty_name as higher_faculty
from students inner join
(select high.student_id, high.high_marks, high.subject_id, high.subject_name, high.faculty_name
from 
(select marks.student_id, marks.marks as high_marks, sub_with_faculty.subject_id, sub_with_faculty.subject_name,
sub_with_faculty.faculty_name from marks
left join
(select students_subject.id as subject_id, students_subject.subject_name, faculty.faculty_name
from students_subject  
left join faculty  on  students_subject.subject_faculty = faculty.id) as sub_with_faculty
on sub_with_faculty.subject_id = marks.subject_id) as high
inner join (select marks.student_id, max(marks) as marks from marks group by 1) as maximum on 
maximum.student_id = high.student_id and maximum.marks = high.high_marks) as hw on
hw.student_id = students.id
inner join
(select low.student_id, low.low_marks as min_marks, low.subject_id as lower_subjectID, low.subject_name as lower_subject, low.faculty_name as lower_faculty
from 
(select marks.student_id, marks.marks as low_marks, sub_with_faculty.subject_id, sub_with_faculty.subject_name,
sub_with_faculty.faculty_name from marks
left join
(select students_subject.id as subject_id, students_subject.subject_name, faculty.faculty_name
from students_subject  
left join faculty  on  students_subject.subject_faculty = faculty.id) as sub_with_faculty
on sub_with_faculty.subject_id = marks.subject_id) as low
inner join (select marks.student_id, min(marks) as marks from marks group by 1) as minimum on 
minimum.student_id = low.student_id and minimum.marks = low.low_marks) as lw on 
lw.student_id = students.id;

Это может быть хорошим упражнением для новичка в MySQL, такого как я.

...