Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
2c15823a
提交
2c15823a
authored
7 年前
作者:
Evgenij Ryazanov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use only constants from Function in DateTimeUtils.getDatePart()
上级
0316d856
master
version-1.4.198
version-1.4.197
无相关合并请求
显示空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
100 行增加
和
85 行删除
+100
-85
Function.java
h2/src/main/org/h2/expression/Function.java
+89
-74
DateTimeUtils.java
h2/src/main/org/h2/util/DateTimeUtils.java
+11
-11
没有找到文件。
h2/src/main/org/h2/expression/Function.java
浏览文件 @
2c15823a
...
...
@@ -108,6 +108,11 @@ public class Function extends Expression implements FunctionCall {
FORMATDATETIME
=
121
,
PARSEDATETIME
=
122
,
ISO_YEAR
=
123
,
ISO_WEEK
=
124
,
ISO_DAY_OF_WEEK
=
125
;
/**
* Pseudo function for {@code EXTRACT(MILLISECOND FROM ...)}.
*/
public
static
final
int
MILLISECOND
=
126
;
public
static
final
int
DATABASE
=
150
,
USER
=
151
,
CURRENT_USER
=
152
,
IDENTITY
=
153
,
SCOPE_IDENTITY
=
154
,
AUTOCOMMIT
=
155
,
READONLY
=
156
,
DATABASE_PATH
=
157
,
LOCK_TIMEOUT
=
158
,
...
...
@@ -158,39 +163,39 @@ public class Function extends Expression implements FunctionCall {
static
{
// DATE_PART
DATE_PART
.
put
(
"SQL_TSI_YEAR"
,
Calendar
.
YEAR
);
DATE_PART
.
put
(
"YEAR"
,
Calendar
.
YEAR
);
DATE_PART
.
put
(
"YYYY"
,
Calendar
.
YEAR
);
DATE_PART
.
put
(
"YY"
,
Calendar
.
YEAR
);
DATE_PART
.
put
(
"SQL_TSI_MONTH"
,
Calendar
.
MONTH
);
DATE_PART
.
put
(
"MONTH"
,
Calendar
.
MONTH
);
DATE_PART
.
put
(
"MM"
,
Calendar
.
MONTH
);
DATE_PART
.
put
(
"M"
,
Calendar
.
MONTH
);
DATE_PART
.
put
(
"SQL_TSI_WEEK"
,
Calendar
.
WEEK_OF_YEAR
);
DATE_PART
.
put
(
"WW"
,
Calendar
.
WEEK_OF_YEAR
);
DATE_PART
.
put
(
"WK"
,
Calendar
.
WEEK_OF_YEAR
);
DATE_PART
.
put
(
"WEEK"
,
Calendar
.
WEEK_OF_YEAR
);
DATE_PART
.
put
(
"DAY"
,
Calendar
.
DAY_OF_MONTH
);
DATE_PART
.
put
(
"DD"
,
Calendar
.
DAY_OF_MONTH
);
DATE_PART
.
put
(
"D"
,
Calendar
.
DAY_OF_MONTH
);
DATE_PART
.
put
(
"SQL_TSI_DAY"
,
Calendar
.
DAY_OF_MONTH
);
DATE_PART
.
put
(
"DAYOFYEAR"
,
Calendar
.
DAY_OF_YEAR
);
DATE_PART
.
put
(
"DAY_OF_YEAR"
,
Calendar
.
DAY_OF_YEAR
);
DATE_PART
.
put
(
"DY"
,
Calendar
.
DAY_OF_YEAR
);
DATE_PART
.
put
(
"DOY"
,
Calendar
.
DAY_OF_YEAR
);
DATE_PART
.
put
(
"SQL_TSI_HOUR"
,
Calendar
.
HOUR_OF_DAY
);
DATE_PART
.
put
(
"HOUR"
,
Calendar
.
HOUR_OF_DAY
);
DATE_PART
.
put
(
"HH"
,
Calendar
.
HOUR_OF_DAY
);
DATE_PART
.
put
(
"SQL_TSI_MINUTE"
,
Calendar
.
MINUTE
);
DATE_PART
.
put
(
"MINUTE"
,
Calendar
.
MINUTE
);
DATE_PART
.
put
(
"MI"
,
Calendar
.
MINUTE
);
DATE_PART
.
put
(
"N"
,
Calendar
.
MINUTE
);
DATE_PART
.
put
(
"SQL_TSI_SECOND"
,
Calendar
.
SECOND
);
DATE_PART
.
put
(
"SECOND"
,
Calendar
.
SECOND
);
DATE_PART
.
put
(
"SS"
,
Calendar
.
SECOND
);
DATE_PART
.
put
(
"S"
,
Calendar
.
SECOND
);
DATE_PART
.
put
(
"MILLISECOND"
,
Calendar
.
MILLISECOND
);
DATE_PART
.
put
(
"MS"
,
Calendar
.
MILLISECOND
);
DATE_PART
.
put
(
"SQL_TSI_YEAR"
,
YEAR
);
DATE_PART
.
put
(
"YEAR"
,
YEAR
);
DATE_PART
.
put
(
"YYYY"
,
YEAR
);
DATE_PART
.
put
(
"YY"
,
YEAR
);
DATE_PART
.
put
(
"SQL_TSI_MONTH"
,
MONTH
);
DATE_PART
.
put
(
"MONTH"
,
MONTH
);
DATE_PART
.
put
(
"MM"
,
MONTH
);
DATE_PART
.
put
(
"M"
,
MONTH
);
DATE_PART
.
put
(
"SQL_TSI_WEEK"
,
WEEK
);
DATE_PART
.
put
(
"WW"
,
WEEK
);
DATE_PART
.
put
(
"WK"
,
WEEK
);
DATE_PART
.
put
(
"WEEK"
,
WEEK
);
DATE_PART
.
put
(
"DAY"
,
DAY_OF_MONTH
);
DATE_PART
.
put
(
"DD"
,
DAY_OF_MONTH
);
DATE_PART
.
put
(
"D"
,
DAY_OF_MONTH
);
DATE_PART
.
put
(
"SQL_TSI_DAY"
,
DAY_OF_MONTH
);
DATE_PART
.
put
(
"DAYOFYEAR"
,
DAY_OF_YEAR
);
DATE_PART
.
put
(
"DAY_OF_YEAR"
,
DAY_OF_YEAR
);
DATE_PART
.
put
(
"DY"
,
DAY_OF_YEAR
);
DATE_PART
.
put
(
"DOY"
,
DAY_OF_YEAR
);
DATE_PART
.
put
(
"SQL_TSI_HOUR"
,
HOUR
);
DATE_PART
.
put
(
"HOUR"
,
HOUR
);
DATE_PART
.
put
(
"HH"
,
HOUR
);
DATE_PART
.
put
(
"SQL_TSI_MINUTE"
,
MINUTE
);
DATE_PART
.
put
(
"MINUTE"
,
MINUTE
);
DATE_PART
.
put
(
"MI"
,
MINUTE
);
DATE_PART
.
put
(
"N"
,
MINUTE
);
DATE_PART
.
put
(
"SQL_TSI_SECOND"
,
SECOND
);
DATE_PART
.
put
(
"SECOND"
,
SECOND
);
DATE_PART
.
put
(
"SS"
,
SECOND
);
DATE_PART
.
put
(
"S"
,
SECOND
);
DATE_PART
.
put
(
"MILLISECOND"
,
MILLISECOND
);
DATE_PART
.
put
(
"MS"
,
MILLISECOND
);
// SOUNDEX_INDEX
String
index
=
"7AEIOUY8HW1BFPV2CGJKQSXZ3DT4L5MN6R"
;
...
...
@@ -837,45 +842,27 @@ public class Function extends Expression implements FunctionCall {
break
;
}
case
DAY_OF_MONTH:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
DAY_OF_MONTH
));
break
;
case
DAY_OF_WEEK:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
DAY_OF_WEEK
));
break
;
case
DAY_OF_YEAR:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
DAY_OF_YEAR
));
break
;
case
HOUR:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
HOUR_OF_DAY
));
break
;
case
MINUTE:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
MINUTE
));
break
;
case
MONTH:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
MONTH
));
break
;
case
MONTH_NAME:
{
SimpleDateFormat
monthName
=
new
SimpleDateFormat
(
"MMMM"
,
Locale
.
ENGLISH
);
result
=
ValueString
.
get
(
monthName
.
format
(
v0
.
getDate
()),
database
.
getMode
().
treatEmptyStringsAsNull
);
break
;
}
case
QUARTER:
case
ISO_YEAR:
case
ISO_WEEK:
case
ISO_DAY_OF_WEEK:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
info
.
type
));
break
;
case
SECOND:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
SECOND
));
break
;
case
WEEK:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
WEEK_OF_YEAR
));
break
;
case
YEAR:
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
Calendar
.
YEAR
));
result
=
ValueInt
.
get
(
DateTimeUtils
.
getDatePart
(
v0
,
info
.
type
));
break
;
case
MONTH_NAME:
{
SimpleDateFormat
monthName
=
new
SimpleDateFormat
(
"MMMM"
,
Locale
.
ENGLISH
);
result
=
ValueString
.
get
(
monthName
.
format
(
v0
.
getDate
()),
database
.
getMode
().
treatEmptyStringsAsNull
);
break
;
}
case
CURDATE:
case
CURRENT_DATE:
{
long
now
=
session
.
getTransactionStart
();
...
...
@@ -1821,11 +1808,39 @@ public class Function extends Expression implements FunctionCall {
private
static
Timestamp
dateadd
(
String
part
,
long
count
,
Timestamp
d
)
{
int
field
=
getDatePart
(
part
);
if
(
field
==
Calendar
.
MILLISECOND
)
{
switch
(
field
)
{
case
YEAR:
field
=
Calendar
.
YEAR
;
break
;
case
MONTH:
field
=
Calendar
.
MONTH
;
break
;
case
DAY_OF_MONTH:
field
=
Calendar
.
DAY_OF_MONTH
;
break
;
case
DAY_OF_YEAR:
field
=
Calendar
.
DAY_OF_YEAR
;
break
;
case
WEEK:
field
=
Calendar
.
WEEK_OF_YEAR
;
break
;
case
HOUR:
field
=
Calendar
.
HOUR_OF_DAY
;
break
;
case
MINUTE:
field
=
Calendar
.
MINUTE
;
break
;
case
SECOND:
field
=
Calendar
.
SECOND
;
break
;
case
MILLISECOND:
{
Timestamp
ts
=
new
Timestamp
(
d
.
getTime
()
+
count
);
ts
.
setNanos
(
ts
.
getNanos
()
+
(
d
.
getNanos
()
%
1000000
));
return
ts
;
}
default
:
throw
DbException
.
getUnsupportedException
(
"DATEADD "
+
part
);
}
// We allow long for manipulating the millisecond component,
// for the rest we only allow int.
if
(
count
>
Integer
.
MAX_VALUE
)
{
...
...
@@ -1872,34 +1887,34 @@ public class Function extends Expression implements FunctionCall {
calendar
.
get
(
Calendar
.
DAY_OF_WEEK
),
calendar
.
get
(
Calendar
.
MILLISECOND
));
switch
(
field
)
{
case
Calendar
.
MILLISECOND
:
case
Function
.
MILLISECOND
:
return
t2
-
t1
;
case
Calendar
.
SECOND
:
case
Calendar
.
MINUTE
:
case
Calendar
.
HOUR_OF_DAY
:
case
Calendar
.
DAY_OF_YEAR
:
case
Calendar
.
WEEK_OF_YEAR
:
{
case
Function
.
SECOND
:
case
Function
.
MINUTE
:
case
Function
.
HOUR
:
case
Function
.
DAY_OF_YEAR
:
case
Function
.
WEEK
:
{
// first 'normalize' the numbers so both are not negative
long
hour
=
60
*
60
*
1000
;
long
add
=
Math
.
min
(
t1
/
hour
*
hour
,
t2
/
hour
*
hour
);
t1
-=
add
;
t2
-=
add
;
switch
(
field
)
{
case
Calendar
.
SECOND
:
case
Function
.
SECOND
:
return
t2
/
1000
-
t1
/
1000
;
case
Calendar
.
MINUTE
:
case
Function
.
MINUTE
:
return
t2
/
(
60
*
1000
)
-
t1
/
(
60
*
1000
);
case
Calendar
.
HOUR_OF_DAY
:
case
Function
.
HOUR
:
return
t2
/
hour
-
t1
/
hour
;
case
Calendar
.
DAY_OF_YEAR
:
case
Function
.
DAY_OF_YEAR
:
return
t2
/
(
hour
*
24
)
-
t1
/
(
hour
*
24
);
case
Calendar
.
WEEK_OF_YEAR
:
case
Function
.
WEEK
:
return
t2
/
(
hour
*
24
*
7
)
-
t1
/
(
hour
*
24
*
7
);
default
:
throw
DbException
.
throwInternalError
(
"field:"
+
field
);
}
}
case
Calendar
.
DATE
:
case
Function
.
DAY_OF_MONTH
:
return
t2
/
(
24
*
60
*
60
*
1000
)
-
t1
/
(
24
*
60
*
60
*
1000
);
default
:
break
;
...
...
@@ -1912,9 +1927,9 @@ public class Function extends Expression implements FunctionCall {
int
year2
=
calendar
.
get
(
Calendar
.
YEAR
);
int
month2
=
calendar
.
get
(
Calendar
.
MONTH
);
int
result
=
year2
-
year1
;
if
(
field
==
Calendar
.
MONTH
)
{
if
(
field
==
Function
.
MONTH
)
{
return
12
*
result
+
(
month2
-
month1
);
}
else
if
(
field
==
Calendar
.
YEAR
)
{
}
else
if
(
field
==
Function
.
YEAR
)
{
return
result
;
}
else
{
throw
DbException
.
getUnsupportedException
(
"DATEDIFF "
+
part
);
...
...
This diff is collapsed.
Click to expand it.
h2/src/main/org/h2/util/DateTimeUtils.java
浏览文件 @
2c15823a
...
...
@@ -566,7 +566,7 @@ public class DateTimeUtils {
* positive or negative, and month starting with 1.
*
* @param date the date value
* @param field the field type
* @param field the field type
, see {@link Function} for constants
* @return the value
*/
public
static
int
getDatePart
(
Value
date
,
int
field
)
{
...
...
@@ -590,25 +590,25 @@ public class DateTimeUtils {
timeNanos
=
v
.
getTimeNanos
();
}
switch
(
field
)
{
case
Calendar
.
YEAR
:
case
Function
.
YEAR
:
return
yearFromDateValue
(
dateValue
);
case
Calendar
.
MONTH
:
case
Function
.
MONTH
:
return
monthFromDateValue
(
dateValue
);
case
Calendar
.
DAY_OF_MONTH
:
case
Function
.
DAY_OF_MONTH
:
return
dayFromDateValue
(
dateValue
);
case
Calendar
.
HOUR_OF_DAY
:
case
Function
.
HOUR
:
return
(
int
)
(
timeNanos
/
3_600_000_000_000L
%
24
);
case
Calendar
.
MINUTE
:
case
Function
.
MINUTE
:
return
(
int
)
(
timeNanos
/
60_000_000_000L
%
60
);
case
Calendar
.
SECOND
:
case
Function
.
SECOND
:
return
(
int
)
(
timeNanos
/
1_000_000_000
%
60
);
case
Calendar
.
MILLISECOND
:
case
Function
.
MILLISECOND
:
return
(
int
)
(
timeNanos
/
1_000_000
%
1_000
);
case
Calendar
.
DAY_OF_YEAR
:
case
Function
.
DAY_OF_YEAR
:
return
getDayOfYear
(
dateValue
);
case
Calendar
.
DAY_OF_WEEK
:
case
Function
.
DAY_OF_WEEK
:
return
getSundayDayOfWeek
(
dateValue
);
case
Calendar
.
WEEK_OF_YEAR
:
case
Function
.
WEEK
:
GregorianCalendar
gc
=
getCalendar
();
return
getWeekOfYear
(
dateValue
,
gc
.
getFirstDayOfWeek
()
-
1
,
gc
.
getMinimalDaysInFirstWeek
());
case
Function
.
QUARTER
:
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论