Error number: 3912; Symbol: ER_GROUPING_ON_TIMESTAMP_IN_DST; SQLSTATE: HY000
Message: Grouping on temporal is non-deterministic for timezones having DST. Please consider switching to UTC for this query.
错误说明:
ER_GROUPING_ON_TIMESTAMP_IN_DST是一个MySQL错误,它指示不允许在夏令时(DST)中对时间戳字段进行分组。它也表示MySQL不支持DST转换也就是指夏令时-消失或创建时间轴的改变。
从夏令时到标准时间,这会使一些数据不能用于分组,从而导致出现这个错误。例如,如果有一个MySQL查询试图使用COUNT()函数分组一个TIMESTAMP字段,它就可能会出现ER_GROUPING_ON_TIMESTAMP_IN_DST错误。
解决方法:
要解决ER_GROUPING_ON_TIMESTAMP_IN_DST错误,首先要确保天文时间正确设置,无论用户是否在夏令时期间运行。
另外您可以尝试将TIMESTAMP转换为DATETIME 并分组,因为DATETIME数据没有跨夏令时转换的问题。
比如,以下查询使用CONVERT()把TIMESTAMP字段转换为DATETIME,然后根据这个字段的值来使用COUNT()函数分组:
SELECT COUNT(*) AS COUNT FROM t1 GROUP BY CONVERT(DATETIME,t1.time_col);
另外,您还可以重新编写查询,使用另一种分组方式,如果写的查询正确的话,这将解决您的问题,否则返回ER_GROUPING_ON_TIMESTAMP_IN_DST错误。