首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >H2 FORMATDATETIME()

H2 FORMATDATETIME()
EN

Stack Overflow用户
提问于 2017-05-09 12:36:38
回答 1查看 2K关注 0票数 1

我试图在一个日期中将分钟和秒设置为00,我使用了格式化时间(日期,‘Y-MM- the :00:00“),它在正常日期中运行良好,但是尝试使用格式化时间(’2017-01-01 12:27:27',‘Y-MM- the :00:00’)结果是2016-01-01 12:00:00,而不是2017-01-01 12:00:00 :00。为什么?

下面是一些示例代码:

代码语言:javascript
复制
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;

结果是:

代码语言:javascript
复制
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。

SELECT timestamp FROM test_table的输出是正常的:

代码语言:javascript
复制
TIMESTAMP ▼
2017-01-01 12:27:27.0
2017-01-02 12:27:27.0
2017-01-03 12:27:27.0

编辑:我发现了问题,似乎是地区问题:

来自SELECT FORMATDATETIME(timestamp, 'Y-MM-dd HH:00:00 z', 'it', 'GMT') FROM test_table的输出

代码语言:javascript
复制
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

来自SELECT FORMATDATETIME(timestamp, 'Y-MM-dd HH:00:00 z', 'en', 'GMT') FROM test_table的输出

代码语言:javascript
复制
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语言环境,它在2017年01月01日减去一年,而在en地区则没有。有人能解释一下为什么会发生这种情况吗?区域设置不应该只更改数据表示吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-05-12 07:47:54

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

正如亨德里克在其评论中所建议的那样,H2使用Java SimpleDateFormat来格式化日期。在SimpleDateFormat格式之后,'Y‘(大写)表示week Y(该周所属的年份)。

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43870019

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档