• 美好生活的价值追求和实现路径-社会关注-理论频道-中工网 2018-05-21
  • 保罗亲手为自己圆梦 火箭勇士双双会师西部决赛 2018-05-21
  • Floating production, storage and offloading vessel delivered in Qingdao 2018-05-20
  • 汽車定位跟蹤官員意圖敲詐 追蹤器該怎麼管 2018-05-20
  • 工作队精准发力助力贫困村“摘帽” 2018-05-20
  • 中消协发布榨汁机比较试验结果 2018-05-20
  • 游花海林芝,赏野生桃花 2018林芝桃花节29日开幕 2018-05-20
  • 19米99轻松卫冕 巩立姣:没突破20米有点可惜 2018-05-18
  • 海南省工商局出实招提高干部素质 强化工作作风 2018-05-18
  • 栾蕾英亮相TOP100时尚盛典 盛装亮相仙气十足 2018-05-18
  • 以合法形式掩盖非法目的的合同效力 2018-05-18
  • 4月解放领跑重卡行业 红岩保持增幅第一 2018-05-17
  • 不查“后来”,中国电影难有未来 2018-05-16
  • 欧盟公司与伊朗合作将遭美国制裁?德媒:欧美或渐行渐远 2018-05-16
  • 《青草的清香》:探索感官和情感的发展史 2018-05-16
  • Kevensuu's Blog

    mysql group_concat 用法

    需求:从一批数据中,按 live_id 分组取 id 最大的一个值,并按照 sort desc create_time 排序

    测试数据如下:

    可以看到有些 live_id 对应多条数据记录

    解决方法:

    $sql = "select 
            SUBSTRING_INDEX(group_concat(lpad(sort, 5, 0) order by id desc),',', 1) as sort,
            SUBSTRING_INDEX(group_concat(id order by id desc),',', 1) as id,
            SUBSTRING_INDEX(group_concat(create_time order by id desc),',', 1) as create_time
            from live_view where is_show=1 and status=0 group by live_id order by sort desc,create_time desc  limit {$limit},{$pagesize}";
            $ret = $this->fetchAllRows($sql);
            if(!$ret)
            {
                return array();
            }
    
            $ids = array();
            foreach ($ret as $value)
            {
                $ids[] = $value['id'];
            }
            $ids_str = implode(',', $ids);
    
            $sql = "select {$viewfields} from live_view
                    where id in({$ids_str}) order by sort DESC,create_time DESC ";
            $ret = $this->fetchAllRows($sql);
    

    从代码中看到,我们先通过 group_concat SUBSTRING_INDEX 两个函数获获取到想要的数据 ID,再根据这些 ID 来获取其余字段信息