Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
8075f8dd
提交
8075f8dd
authored
7 年前
作者:
Evgenij Ryazanov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Properly implement TZR and TZD in TO_CHAR for TIMESTAMP WITH TIME ZONE
上级
11af9ca4
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
22 行增加
和
3 行删除
+22
-3
ToChar.java
h2/src/main/org/h2/util/ToChar.java
+5
-2
ValueTimestampTimeZone.java
h2/src/main/org/h2/value/ValueTimestampTimeZone.java
+13
-1
TestFunctions.java
h2/src/test/org/h2/test/db/TestFunctions.java
+4
-0
没有找到文件。
h2/src/main/org/h2/util/ToChar.java
浏览文件 @
8075f8dd
...
...
@@ -18,6 +18,7 @@ import java.util.TimeZone;
import
org.h2.api.ErrorCode
;
import
org.h2.message.DbException
;
import
org.h2.value.Value
;
import
org.h2.value.ValueTimestampTimeZone
;
/**
* Emulates Oracle's TO_CHAR function.
...
...
@@ -754,11 +755,13 @@ public class ToChar {
// Time zone
}
else
if
(
containsAt
(
format
,
i
,
"TZR"
)
!=
null
)
{
TimeZone
tz
=
TimeZone
.
getDefault
();
TimeZone
tz
=
value
instanceof
ValueTimestampTimeZone
?
((
ValueTimestampTimeZone
)
value
).
getTimeZone
()
:
TimeZone
.
getDefault
();
output
.
append
(
tz
.
getID
());
i
+=
3
;
}
else
if
(
containsAt
(
format
,
i
,
"TZD"
)
!=
null
)
{
TimeZone
tz
=
TimeZone
.
getDefault
();
TimeZone
tz
=
value
instanceof
ValueTimestampTimeZone
?
((
ValueTimestampTimeZone
)
value
).
getTimeZone
()
:
TimeZone
.
getDefault
();
boolean
daylight
=
tz
.
inDaylightTime
(
new
java
.
util
.
Date
());
output
.
append
(
tz
.
getDisplayName
(
daylight
,
TimeZone
.
SHORT
));
i
+=
3
;
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/value/ValueTimestampTimeZone.java
浏览文件 @
8075f8dd
...
...
@@ -15,6 +15,7 @@ import org.h2.api.ErrorCode;
import
org.h2.api.TimestampWithTimeZone
;
import
org.h2.message.DbException
;
import
org.h2.util.DateTimeUtils
;
import
org.h2.util.StringUtils
;
/**
* Implementation of the TIMESTAMP WITH TIME ZONE data type.
...
...
@@ -158,7 +159,18 @@ public class ValueTimestampTimeZone extends Value {
if
(
offset
==
0
)
{
return
DateTimeUtils
.
UTC
;
}
return
new
SimpleTimeZone
(
offset
*
60000
,
Integer
.
toString
(
offset
));
StringBuilder
b
=
new
StringBuilder
(
9
);
b
.
append
(
"GMT"
);
if
(
offset
<
0
)
{
b
.
append
(
'-'
);
offset
=
-
offset
;
}
else
{
b
.
append
(
'+'
);
}
StringUtils
.
appendZeroPadded
(
b
,
2
,
offset
/
60
);
b
.
append
(
':'
);
StringUtils
.
appendZeroPadded
(
b
,
2
,
offset
%
60
);
return
new
SimpleTimeZone
(
offset
*
60000
,
b
.
toString
());
}
@Override
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/db/TestFunctions.java
浏览文件 @
8075f8dd
...
...
@@ -1619,6 +1619,10 @@ public class TestFunctions extends TestBase implements AggregateFunction {
assertResult
(
expected
,
stat
,
"SELECT TO_CHAR(X, 'TS') FROM T"
);
assertResult
(
tzLongName
,
stat
,
"SELECT TO_CHAR(X, 'TZR') FROM T"
);
assertResult
(
tzShortName
,
stat
,
"SELECT TO_CHAR(X, 'TZD') FROM T"
);
assertResult
(
"GMT+10:30"
,
stat
,
"SELECT TO_CHAR(TIMESTAMP WITH TIME ZONE '2010-01-01 0:00:00+10:30', 'TZR')"
);
assertResult
(
"GMT+10:30"
,
stat
,
"SELECT TO_CHAR(TIMESTAMP WITH TIME ZONE '2010-01-01 0:00:00+10:30', 'TZD')"
);
expected
=
String
.
format
(
"%f"
,
1.1
).
substring
(
1
,
2
);
assertResult
(
expected
,
stat
,
"SELECT TO_CHAR(X, 'X') FROM T"
);
expected
=
String
.
format
(
"%,d"
,
1979
);
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论