【问题标题】:select the last study (max) course according the user根据用户选择最后学习(最大)课程
【发布时间】:2018-05-14 01:46:46
【问题描述】:

我在做什么?

我正在根据研究显示用户。 我想获取每个用户最后学习的课程。

有问题?

我没有根据上次学习的课程获得最后的课程名称。我得到了第一个课程名称。(java) 但我希望 (oracle) 作为用户最后学习的课程。

用户表

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();

【问题讨论】:

  • 您的预期结果集错误应该是紫山的C++?同样对于 Ellen 为什么 dot net 为什么不使用 oracle 两者都在同一年
  • @MKhalidJunaid for ellen 只有一个条目,所以 dot net 是正确的,但是我同意 zishan 它应该是 c++

标签: php sql codeigniter greatest-n-per-group


【解决方案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

Demo

请注意,如果它们共享同一年,它可能会返回多个课程

等效的活动记录查询将类似于

$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();

【讨论】:

  • 先生,我在结果中得到了空白数组,但我没有得到 WHERE c1.user_id` 为 null` 这是干什么用的??
  • @always-a-learner 我没有得到那个空白数组部分?愿你能展示你的代码你是如何操纵这个查询的。年份最高的行将在左连接中有一个空行,以获得需要此过滤器的最高行
  • 我添加了有问题的 Active Record Query
  • @always-a-learner 我添加了查询的活动记录版本。您尝试的查询与我的回答建议的不同
  • 非常感谢您的先生。它正在工作。实际上,在我身边需要一段时间才能理解。非常感谢。
【解决方案2】:

使用下面的子查询

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
                )

【讨论】:

    【解决方案3】:

    您的查询不起作用,因为您需要提供 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;  
    

    如有任何疑问,请告诉我。

    【讨论】:

    • @always-a-learner 如果解决了您的问题,请接受答案
    • 先生,我正在测试它
    【解决方案4】:

    这样试试;

    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
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-12-24
      • 2020-02-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多