Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
aac17564
Unverified
提交
aac17564
authored
7 年前
作者:
Noel Grandin
提交者:
GitHub
7 年前
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #878 from katzyn/datetime
Fix IYYY in TO_CHAR and reimplement TRUNCATE without a Calendar
上级
296a1608
8075f8dd
master
version-1.4.198
version-1.4.197
无相关合并请求
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
85 行增加
和
60 行删除
+85
-60
Function.java
h2/src/main/org/h2/expression/Function.java
+8
-25
ToChar.java
h2/src/main/org/h2/util/ToChar.java
+49
-34
ValueTimestampTimeZone.java
h2/src/main/org/h2/value/ValueTimestampTimeZone.java
+13
-1
TestFunctions.java
h2/src/test/org/h2/test/db/TestFunctions.java
+15
-0
没有找到文件。
h2/src/main/org/h2/expression/Function.java
浏览文件 @
aac17564
...
...
@@ -17,7 +17,6 @@ import java.sql.ResultSet;
import
java.sql.SQLException
;
import
java.text.SimpleDateFormat
;
import
java.util.ArrayList
;
import
java.util.Calendar
;
import
java.util.GregorianCalendar
;
import
java.util.HashMap
;
import
java.util.Locale
;
...
...
@@ -1233,32 +1232,16 @@ public class Function extends Expression implements FunctionCall {
}
case
TRUNCATE:
{
if
(
v0
.
getType
()
==
Value
.
TIMESTAMP
)
{
java
.
sql
.
Timestamp
d
=
v0
.
getTimestamp
();
Calendar
c
=
DateTimeUtils
.
createGregorianCalendar
();
c
.
setTime
(
d
);
c
.
set
(
Calendar
.
HOUR_OF_DAY
,
0
);
c
.
set
(
Calendar
.
MINUTE
,
0
);
c
.
set
(
Calendar
.
SECOND
,
0
);
c
.
set
(
Calendar
.
MILLISECOND
,
0
);
result
=
ValueTimestamp
.
fromMillis
(
c
.
getTimeInMillis
());
result
=
ValueTimestamp
.
fromDateValueAndNanos
(((
ValueTimestamp
)
v0
).
getDateValue
(),
0
);
}
else
if
(
v0
.
getType
()
==
Value
.
DATE
)
{
ValueDate
vd
=
(
ValueDate
)
v0
;
Calendar
c
=
DateTimeUtils
.
createGregorianCalendar
();
c
.
setTime
(
vd
.
getDate
());
c
.
set
(
Calendar
.
HOUR_OF_DAY
,
0
);
c
.
set
(
Calendar
.
MINUTE
,
0
);
c
.
set
(
Calendar
.
SECOND
,
0
);
c
.
set
(
Calendar
.
MILLISECOND
,
0
);
result
=
ValueTimestamp
.
fromMillis
(
c
.
getTimeInMillis
());
result
=
ValueTimestamp
.
fromDateValueAndNanos
(((
ValueDate
)
v0
).
getDateValue
(),
0
);
}
else
if
(
v0
.
getType
()
==
Value
.
TIMESTAMP_TZ
)
{
ValueTimestampTimeZone
ts
=
(
ValueTimestampTimeZone
)
v0
;
result
=
ValueTimestampTimeZone
.
fromDateValueAndNanos
(
ts
.
getDateValue
(),
0
,
ts
.
getTimeZoneOffsetMins
());
}
else
if
(
v0
.
getType
()
==
Value
.
STRING
)
{
ValueString
vd
=
(
ValueString
)
v0
;
Calendar
c
=
DateTimeUtils
.
createGregorianCalendar
();
c
.
setTime
(
ValueTimestamp
.
parse
(
vd
.
getString
(),
session
.
getDatabase
().
getMode
()).
getDate
());
c
.
set
(
Calendar
.
HOUR_OF_DAY
,
0
);
c
.
set
(
Calendar
.
MINUTE
,
0
);
c
.
set
(
Calendar
.
SECOND
,
0
);
c
.
set
(
Calendar
.
MILLISECOND
,
0
);
result
=
ValueTimestamp
.
fromMillis
(
c
.
getTimeInMillis
());
ValueTimestamp
ts
=
ValueTimestamp
.
parse
(
v0
.
getString
(),
session
.
getDatabase
().
getMode
());
result
=
ValueTimestamp
.
fromDateValueAndNanos
(
ts
.
getDateValue
(),
0
);
}
else
{
double
d
=
v0
.
getDouble
();
int
p
=
v1
==
null
?
0
:
v1
.
getInt
();
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/util/ToChar.java
浏览文件 @
aac17564
差异被折叠。
点击展开。
h2/src/main/org/h2/value/ValueTimestampTimeZone.java
浏览文件 @
aac17564
...
...
@@ -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
浏览文件 @
aac17564
...
...
@@ -1486,6 +1486,17 @@ public class TestFunctions extends TestBase implements AggregateFunction {
assertResult
(
"0 BC"
,
stat
,
"SELECT TO_CHAR(X, 'Y BC') FROM U"
);
assertResult
(
"1979 A.D."
,
stat
,
"SELECT TO_CHAR(X, 'YYYY B.C.') FROM T"
);
assertResult
(
"2013"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'YYYY') FROM DUAL"
);
assertResult
(
"013"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'YYY') FROM DUAL"
);
assertResult
(
"13"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'YY') FROM DUAL"
);
assertResult
(
"3"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'Y') FROM DUAL"
);
// ISO week year
assertResult
(
"2014"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'IYYY') FROM DUAL"
);
assertResult
(
"014"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'IYY') FROM DUAL"
);
assertResult
(
"14"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'IY') FROM DUAL"
);
assertResult
(
"4"
,
stat
,
"SELECT TO_CHAR(DATE '2013-12-30', 'I') FROM DUAL"
);
assertResult
(
"0001"
,
stat
,
"SELECT TO_CHAR(DATE '-0001-01-01', 'IYYY') FROM DUAL"
);
assertResult
(
"0005"
,
stat
,
"SELECT TO_CHAR(DATE '-0004-01-01', 'IYYY') FROM DUAL"
);
assertResult
(
"08:12 AM"
,
stat
,
"SELECT TO_CHAR(X, 'HH:MI AM') FROM T"
);
assertResult
(
"08:12 A.M."
,
stat
,
"SELECT TO_CHAR(X, 'HH:MI A.M.') FROM T"
);
assertResult
(
"02:04 P.M."
,
stat
,
"SELECT TO_CHAR(X, 'HH:MI A.M.') FROM U"
);
...
...
@@ -1608,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
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论