内容简介:mysql中group_concat用法。group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字符串结果。通俗点理解,其实是这样的:group_concat()会计算哪些行属于同一组,将属于同一组的列显示出来。要返回哪些列,由函数参数(就是字段名)决定。分组必须有个标准,就是根据group by指定的列进行分组。
需求:从一批数据中,按 live_id 分组取 id 最大的一个值,并按照 sort desc create_time 排序
测试数据如下:
可以看到有些 live_id 对应多条数据记录
解决方法:
<?php
$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);
从代码中看到,我们先通过 mysql group_concat
SUBSTRING_INDEX
两个函数获获取到想要的数据 ID,再根据这些 ID 来获取其余字段信息
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据结构、算法与应用(原书第2版)
Sartaj Sahni / 王立柱、刘志红 / 机械工业出版社 / 2015-4 / 79.00元
《数据结构、算法与应用——C++语言描述》是享有盛誉的数据结构教科书的第2版。它完整地包含了基本数据结构的内容,是CS2课程的理想用书。作者Sartaj Sahni通过循循善诱的讲解、直观具体的讨论和基于现实的应用,让读者轻松、愉快地学习。新版书着重利用标准模板库(STL),把书中开发的数据结构和算法与相应的STL实现方法相互关联。本书还增加了很多新的实例和练习题。 书中的应用实例是它的特色......一起来看看 《数据结构、算法与应用(原书第2版)》 这本书的介绍吧!
图片转BASE64编码
在线图片转Base64编码工具
MD5 加密
MD5 加密工具