Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/date/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
H2 FORMATDATETIME()未预料的变化年份01/01_Date_H2_Formatdatetime - Fatal编程技术网

H2 FORMATDATETIME()未预料的变化年份01/01

H2 FORMATDATETIME()未预料的变化年份01/01,date,h2,formatdatetime,Date,H2,Formatdatetime,我试图在一个日期中将分和秒设置为00,我使用formatdatetime(日期,'Y-MM-dd HH:00:00'),它在正常日期下运行良好,但尝试使用formatdatetime('2017-01-01 12:27:27','Y-MM-dd HH:00:00'),结果是2016-01-01 12:00:00,而不是2017-01-01 12:00:00。 为什么? 以下是一些示例代码: CREATE TABLE test_table ( timestamp DATETIME(3) NOT N

我试图在一个日期中将分和秒设置为00,我使用formatdatetime(日期,'Y-MM-dd HH:00:00'),它在正常日期下运行良好,但尝试使用formatdatetime('2017-01-01 12:27:27','Y-MM-dd HH:00:00'),结果是2016-01-01 12:00:00,而不是2017-01-01 12:00:00。 为什么?

以下是一些示例代码:

CREATE TABLE test_table (
timestamp DATETIME(3) NOT NULL
);

INSERT INTO test_table
VALUES 
('2017-01-01 12:27:27'), 
('2017-01-02 12:27:27'), 
('2017-01-03 12:27:27');

SELECT FORMATDATETIME(timestamp, 'Y-MM-dd HH:00:00')
FROM test_table;
结果是:

FORMATDATETIME(TIMESTAMP, 'Y-MM-dd HH:00:00')  
2016-01-01 12:00:00
2017-01-02 12:00:00
2017-01-03 12:00:00
为什么会有这种行为

我试过使用H2 1.4.192/JDK 1.7.0_80和H2 1.4.195/JRE 1.8.0_74

从测试表中选择时间戳的
输出正常:

TIMESTAMP ▼
2017-01-01 12:27:27.0
2017-01-02 12:27:27.0
2017-01-03 12:27:27.0
编辑: 我发现了问题,似乎是区域设置的问题:

从测试表中选择FORMATDATETIME(时间戳'Y-MM-dd HH:00:00 z','it','GMT')的输出

FORMATDATETIME(TIMESTAMP, 'Y-MM-dd HH:00:00 z', 'it')  
2016-01-01 12:00:00 CET
2017-01-02 12:00:00 CET
2017-01-03 12:00:00 CET
FORMATDATETIME(TIMESTAMP, 'Y-MM-dd HH:00:00 z', 'en')  
2017-01-01 12:00:00 CET
2017-01-02 12:00:00 CET
2017-01-03 12:00:00 CET
从测试表中选择FORMATDATETIME(时间戳'Y-MM-dd HH:00:00 z','en','GMT')的输出

FORMATDATETIME(TIMESTAMP, 'Y-MM-dd HH:00:00 z', 'it')  
2016-01-01 12:00:00 CET
2017-01-02 12:00:00 CET
2017-01-03 12:00:00 CET
FORMATDATETIME(TIMESTAMP, 'Y-MM-dd HH:00:00 z', 'en')  
2017-01-01 12:00:00 CET
2017-01-02 12:00:00 CET
2017-01-03 12:00:00 CET

对于
it
locale,它在2017年1月1日减去一年,而对于
en
locale,它不减去一年。有人能解释一下为什么会发生这种情况吗?区域设置不应该只更改数据表示吗?

确定问题已解决,这是我对日期格式的误解:

正如亨德里克在评论中建议的那样,H2使用Java SimpleDataFormat格式化日期。后面的“Y”(大写)代表周年(周所属的年份)


现在2017年1月1日是周日。在意大利地区(在我的机器上使用),星期天被视为一周的最后一天(因此这一周属于过去的一年,2016年),而在国际标准中(在英语地区也是如此),星期天是一周的第一天,然后属于2017年。

确定问题解决了,这是我对日期格式的误解:

正如亨德里克在评论中建议的那样,H2使用Java SimpleDataFormat格式化日期。后面的“Y”(大写)代表周年(周所属的年份)


现在2017年1月1日是周日。在意大利地区(在我的机器上使用),星期天被视为一周的最后一天(因此这一周属于过去的一年,2016年),而在国际标准中(在英语地区也是如此),星期天是一周的第一天,然后属于2017年。

我试图复制您的问题,但失败了。您可能想提及您正在使用的H2和Java版本。另外,
selecttimestamp fromtest_表的输出是什么?如果您在
FORMATDATETIME()
调用中指定了目标时区呢?使用futher Developments编辑假设H2内部使用
SimpleDateFormat
。您能否仅使用
SimpleDataFormat
重现问题?我已尝试重现您的问题,但失败。您可能想提及您正在使用的H2和Java版本。另外,
selecttimestamp fromtest_表的输出是什么?如果您在
FORMATDATETIME()
调用中指定了目标时区呢?使用futher Developments编辑假设H2内部使用
SimpleDateFormat
。您能否仅使用
SimpleDataFormat
重现该问题?