MySQL Error number: 3912; Symbol: ER_GROUPING_ON_TIMESTAMP_IN_DST; SQLSTATE: HY000

文档解释

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错误。

你可能感兴趣的