using Max and Avg function together in SQL












0















I have the following four tables containing student information, lecture information, attending lectures information and exams.



using the
SELECT Student_id, AVG(marks) as average FROM exams GROUP BY Student_id;
I get a list of average marks obtained by each student.



How do i combine it with MAX function to get the ID, name, and average of students who has the highest average in the list?



students



student_id

student_name



lectures



lecture_id

lecture_name

ECTS



attending_lectures



id

student_id

lecture_id



exams



id

Student_id

Lecture_id

Marks










share|improve this question























  • Which DBMS are you using?

    – Barbaros Özhan
    Nov 21 '18 at 18:14











  • mysql and oracle

    – Faaeq
    Nov 21 '18 at 18:20
















0















I have the following four tables containing student information, lecture information, attending lectures information and exams.



using the
SELECT Student_id, AVG(marks) as average FROM exams GROUP BY Student_id;
I get a list of average marks obtained by each student.



How do i combine it with MAX function to get the ID, name, and average of students who has the highest average in the list?



students



student_id

student_name



lectures



lecture_id

lecture_name

ECTS



attending_lectures



id

student_id

lecture_id



exams



id

Student_id

Lecture_id

Marks










share|improve this question























  • Which DBMS are you using?

    – Barbaros Özhan
    Nov 21 '18 at 18:14











  • mysql and oracle

    – Faaeq
    Nov 21 '18 at 18:20














0












0








0








I have the following four tables containing student information, lecture information, attending lectures information and exams.



using the
SELECT Student_id, AVG(marks) as average FROM exams GROUP BY Student_id;
I get a list of average marks obtained by each student.



How do i combine it with MAX function to get the ID, name, and average of students who has the highest average in the list?



students



student_id

student_name



lectures



lecture_id

lecture_name

ECTS



attending_lectures



id

student_id

lecture_id



exams



id

Student_id

Lecture_id

Marks










share|improve this question














I have the following four tables containing student information, lecture information, attending lectures information and exams.



using the
SELECT Student_id, AVG(marks) as average FROM exams GROUP BY Student_id;
I get a list of average marks obtained by each student.



How do i combine it with MAX function to get the ID, name, and average of students who has the highest average in the list?



students



student_id

student_name



lectures



lecture_id

lecture_name

ECTS



attending_lectures



id

student_id

lecture_id



exams



id

Student_id

Lecture_id

Marks







sql max average






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 21 '18 at 18:05









FaaeqFaaeq

61




61













  • Which DBMS are you using?

    – Barbaros Özhan
    Nov 21 '18 at 18:14











  • mysql and oracle

    – Faaeq
    Nov 21 '18 at 18:20



















  • Which DBMS are you using?

    – Barbaros Özhan
    Nov 21 '18 at 18:14











  • mysql and oracle

    – Faaeq
    Nov 21 '18 at 18:20

















Which DBMS are you using?

– Barbaros Özhan
Nov 21 '18 at 18:14





Which DBMS are you using?

– Barbaros Özhan
Nov 21 '18 at 18:14













mysql and oracle

– Faaeq
Nov 21 '18 at 18:20





mysql and oracle

– Faaeq
Nov 21 '18 at 18:20












1 Answer
1






active

oldest

votes


















0














You may use such a SQL with an ORDER BY ... DESC clause to get MAX



For MySQL :



SELECT e.Student_id, s.student_name, AVG(marks) as "average" 
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
ORDER BY "average" DESC
LIMIT 1;


For Oracle :



SELECT * FROM
(
SELECT q.*, row_number() over (order by "average" desc) as rn
FROM
(
SELECT e.Student_id, s.student_name, AVG(marks) as "average"
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
) q
)
WHERE rn = 1;





share|improve this answer


























  • thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

    – Faaeq
    Nov 21 '18 at 18:30













  • @Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

    – Barbaros Özhan
    Nov 21 '18 at 18:36














Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53418121%2fusing-max-and-avg-function-together-in-sql%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









0














You may use such a SQL with an ORDER BY ... DESC clause to get MAX



For MySQL :



SELECT e.Student_id, s.student_name, AVG(marks) as "average" 
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
ORDER BY "average" DESC
LIMIT 1;


For Oracle :



SELECT * FROM
(
SELECT q.*, row_number() over (order by "average" desc) as rn
FROM
(
SELECT e.Student_id, s.student_name, AVG(marks) as "average"
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
) q
)
WHERE rn = 1;





share|improve this answer


























  • thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

    – Faaeq
    Nov 21 '18 at 18:30













  • @Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

    – Barbaros Özhan
    Nov 21 '18 at 18:36


















0














You may use such a SQL with an ORDER BY ... DESC clause to get MAX



For MySQL :



SELECT e.Student_id, s.student_name, AVG(marks) as "average" 
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
ORDER BY "average" DESC
LIMIT 1;


For Oracle :



SELECT * FROM
(
SELECT q.*, row_number() over (order by "average" desc) as rn
FROM
(
SELECT e.Student_id, s.student_name, AVG(marks) as "average"
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
) q
)
WHERE rn = 1;





share|improve this answer


























  • thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

    – Faaeq
    Nov 21 '18 at 18:30













  • @Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

    – Barbaros Özhan
    Nov 21 '18 at 18:36
















0












0








0







You may use such a SQL with an ORDER BY ... DESC clause to get MAX



For MySQL :



SELECT e.Student_id, s.student_name, AVG(marks) as "average" 
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
ORDER BY "average" DESC
LIMIT 1;


For Oracle :



SELECT * FROM
(
SELECT q.*, row_number() over (order by "average" desc) as rn
FROM
(
SELECT e.Student_id, s.student_name, AVG(marks) as "average"
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
) q
)
WHERE rn = 1;





share|improve this answer















You may use such a SQL with an ORDER BY ... DESC clause to get MAX



For MySQL :



SELECT e.Student_id, s.student_name, AVG(marks) as "average" 
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
ORDER BY "average" DESC
LIMIT 1;


For Oracle :



SELECT * FROM
(
SELECT q.*, row_number() over (order by "average" desc) as rn
FROM
(
SELECT e.Student_id, s.student_name, AVG(marks) as "average"
FROM exams e
LEFT JOIN students s ON e.Student_id = s.Student_id
GROUP BY e.Student_id, s.student_name
) q
)
WHERE rn = 1;






share|improve this answer














share|improve this answer



share|improve this answer








edited Nov 21 '18 at 18:36

























answered Nov 21 '18 at 18:12









Barbaros ÖzhanBarbaros Özhan

14.6k71634




14.6k71634













  • thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

    – Faaeq
    Nov 21 '18 at 18:30













  • @Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

    – Barbaros Özhan
    Nov 21 '18 at 18:36





















  • thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

    – Faaeq
    Nov 21 '18 at 18:30













  • @Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

    – Barbaros Özhan
    Nov 21 '18 at 18:36



















thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

– Faaeq
Nov 21 '18 at 18:30







thank you for your reply but its not returning what i'm looking for. two of the students has average of 4, but your solution returns the one with average of 2.3333

– Faaeq
Nov 21 '18 at 18:30















@Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

– Barbaros Özhan
Nov 21 '18 at 18:36







@Faaeq you're welcome. Edited the case for Oracle. Are you sure that you included desc keyword for order by clause ?

– Barbaros Özhan
Nov 21 '18 at 18:36






















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53418121%2fusing-max-and-avg-function-together-in-sql%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Guess what letter conforming each word

Run scheduled task as local user group (not BUILTIN)

Port of Spain