выберите последний (максимальный) курс обучения в соответствии с пользователем

Что я делаю?

Я отображаю пользователя в соответствии с изученным там.
Я хочу получить последний курс, изученный каждым пользователем.

Проблема?

Я не получаю название последнего курса в соответствии с последним изученным курсом. Я получаю название первого курса. (Java), но я хочу (оракул), как последний изученный курс пользователем.

Таблица пользователей

user_id | Name
====================
1       | Zishan
2       | Ellen

Таблица курса

course_id | course_name | user_id | course_year
==================================================
1      |  java       | 1       | 2015
2      |  C++        | 1       | 2017
3      |  oracle     | 1       | 2016
4      |  dot net    | 2       | 2016

Таблица результатов

Name    | last_course_name | last_course_year
============================================
Zishan  | java             | 2017
Ellen   | dot net          | 2016

ожидаемый результат

Name    | last_course_name | last_course_year
============================================
Zishan  | C++              | 2017
Ellen   | dot net          | 2016

запрос

SELECT `u`.`name`, MAX(`c`.`course_year`) as last_course_year , `c`.`course_name` as last_course_name
FROM `user` as `u`
LEFT OUTER JOIN `course` as `c` ON `u`.`id` = `c`.`user_id`
GROUP BY `u`.`id`

Активная запись запроса:

$this->db->select('u.name','c.course_name as last_course_name');
$this->db->select_max('c.course_year as last_course_year');
$this->db->from('user as u');
$this->db->join('course as c', 'u.id = c.user_id', 'left');
$this->db->join('course as c1', 'c.user_id = c1.user_id', 'left outer');
$this->db->where('c1.user_id IS NULL', null, false);
$this->db->group_by('u.id');
$user_couse_data_query = $this->db->get();

1

Решение

Здесь вы переходите к последнему ряду из таблицы курсов для каждого студента

SELECT `u`.`name`, `c`.`course_name` as last_course_name ,c.course_year
FROM `user` as `u`
LEFT JOIN `course` as `c` ON `u`.`id` = `c`.`user_id`
LEFT JOIN `course` as `c1` ON `c`.`user_id` = `c1`.`user_id` AND  `c`.`course_year` < `c1`.`course_year`
WHERE `c1`.`user_id` is null

демонстрация

Обратите внимание, что он может вернуть несколько курсов, если они делятся в том же году

Эквивалентный запрос активной записи будет что-то вроде

$this->db->select('u.name','c.course_name as last_course_name','c.course_year as last_course_year');
$this->db->from('user as u');
$this->db->join('course as c', 'u.id = c.user_id', 'left');
$this->db->join('course as c1', 'c.user_id = c1.user_id AND c.course_year < c1.course_year', 'left');
$this->db->where('c1.user_id IS NULL', null, false);
$user_couse_data_query = $this->db->get();
1

Другие решения

Попробуйте вот так;

select U.Name, C.course_name as last_course_name, C2.maxCourseYear as last_course_year from User U
inner join
( select user_id,max(course_year) as maxCourseYear from Course C
group by C.user_id) C
ON U.user_id = C.user_id
inner join Course C2 ON C2.course_year = C.maxCourseYear
1

Ваш запрос не работает, потому что вам нужно дать все столбцы в group by на котором агрегатная функция не применяется.

Попробуйте это:

select c.name,b.last_course_name,a.last_course_year
from
(select user_id,max(course_year) as last_course_year
from course_table
group by user_id) a
left join
course_table b
on a.user_id = b.user_id and a.course_year = b.course_year
left join
user_table c
on a.user_id = c.user_id;

Дайте мне знать в случае каких-либо запросов.

1

Используйте следующий подзапрос

SELECT u.name,
c.course_year as last_course_year,
c.course_name as last_course_name
FROM user as u
LEFT OUTER JOIN course as c ON u.id = c.user_id and
(c.user_id, c.course_year) IN
(
SELECT c.user_id,  MAX(c.course_year)
FROM course as c
GROUP BY c.user_id
)
1
По вопросам рекламы [email protected]