mysql group by max 取出某一字段分组中最大的值

SELECT
	* 
FROM
	(
	SELECT
		record.device_warn_record_id,
		fac.factor_en_name,
		fac.factor_name,
		maxd.factor_id,
		maxd.factor_rtd,
		maxd.rtd_flag,
		maxd.rtd_datatime,
		record.device_code,
		maxd.rtd_datatime AS warnMaxTime,
		unit.unit_name,
		unit.unit_code 
	FROM
		bx_well_device_warn_record record
		LEFT JOIN bx_well_factor fac ON fac.factor_id = record.factor_id 
		AND fac.del_flag = '0'
		LEFT JOIN bx_well_unit unit ON unit.unit_id = fac.factor_unit_id 
		AND unit.del_flag = '0'
		LEFT JOIN (
		SELECT
			* 
		FROM
			(
			SELECT
				det.device_warn_record_id,
				det.factor_rtd,
				det.rtd_flag,
				det.rtd_datatime,
				det.factor_id 
			FROM
				bx_well_device_warn_detail det 
			ORDER BY
				rtd_datatime DESC 
				LIMIT 1,
				100000 
			) dett 
		GROUP BY
			dett.device_warn_record_id 
		) maxd ON maxd.device_warn_record_id = record.device_warn_record_id 
	WHERE
		record.factor_id IN ( '1294102359420841986' ) 
		AND record.`status` = 1 
	ORDER BY
		record.status_up_time DESC 
		LIMIT 1,
		100000 
	) ddet 
GROUP BY
	ddet.factor_id

查看一下这条sql在两个不同版本数据库的执行计划:
MySql 5.7.20:


MySql 5.5.57:

  
对比可以发现5.7版本的MySql在执行这条sql时缺少了一个derived操作,通过查阅相关资料了解到MySql 5.7对子查询进行了优化,认为子查询中的order by可以进行忽略,只要Derived table里不包含如下条件就可以进行优化:

UNION clause
GROUP BY
DISTINCT
Aggregation
LIMIT or OFFSET
这里把链接放上:5.7中Derived table变形记

最后放上相应的解决办法:

--方法一,仅适用于低于5.7版本的MySql--
select * from (select * from A order by time desc) a GROUP BY a.name; 

--方法二--
select * from (select * from A order by time desc limit 999999) a GROUP BY a.name;

--方法三--
select * from A a where N > (select count(*) from A b where b.id= a.id and a.time< b.time) order by a.name,a.time desc;


方法二中使用limit,需要limit的范围足够大能包括所有数据,并且每种分类只会显示一条数据,但是数据较多时运行效率要比方法三快上很多,方法三能够控制每种分类显示多少条数据,把N换成需要显示对应的数字即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您可以使用MySQLGROUP BY语句和MAX()聚合函数来查询表某个时间最大,然后按照某个字段分组。假设您要查询的表名为`table_name`,时间字段为`time_field`,分组字段为`group_field`,则可以使用以下查询语句: ``` SELECT group_field, MAX(time_field) AS max_time FROM table_name GROUP BY group_field; ``` 这将返回每个分组字段最大时间。如果您还需要包括其他字段,则可以将它们添加到SELECT语句,并将它们添加到GROUP BY语句,如下所示: ``` SELECT group_field, other_field, MAX(time_field) AS max_time FROM table_name GROUP BY group_field, other_field; ``` 这将返回每个分组字段和其他字段最大时间。 ### 回答2: 要查询表某个时间字段最大,并按照另一个字段进行分组,可以使用以下SQL语句: ```sql SELECT 分组字段, MAX(时间字段) AS 最大时间 FROM 表名 GROUP BY 分组字段; ``` 具体步骤如下: 1. 使用SELECT语句来选择字段,并使用MAX函数获取时间字段最大。将结果命名为"最大时间"。 2. 使用FROM语句指定要查询的表名。 3. 使用GROUP BY语句来按照指定的字段进行分组。 4. 最后,执行上述SQL语句,查询到表某个时间字段最大,按照某个字段进行分组,并返回结果。 注意事项: - 将"表名"替换为实际的表名。 - 将"时间字段"和"分组字段"替换为实际的字段名。 - 如果要增加其他字段的输出,可在SELECT语句添加。 例如,查询一个名为"orders"的表"order_date"字段最大日期,按照"customer_id"字段进行分组: ```sql SELECT customer_id, MAX(order_date) AS 最大日期 FROM orders GROUP BY customer_id; ``` 这将返回一个结果集,其每个分组的"customer_id"和对应的最大日期。 ### 回答3: 可以通过以下步骤使用MySQL查询表某个时间最大并按照某个字段分组: 1. 使用MAX()函数找到表某个时间字段最大。例如,如果时间字段名为"timestamp",则可以使用以下语句获取最大: SELECT MAX(timestamp) FROM 表名; 2. 使用GROUP BY子句按照某个字段分组。假设要按照字段"category"进行分组,则可以在查询语句添加以下代码: GROUP BY category; 所以,最终的查询语句将类似于: SELECT MAX(timestamp) FROM 表名 GROUP BY category; 以上查询语句将返回每个不同类别的时间字段最大,并按照类别分组。 注意:请将"表名"和"timestamp"字段名替换为实际使用的表和字段名称。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值