Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
d3609029
提交
d3609029
authored
16 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
JaQu improvements
上级
1838ff22
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
27 行增加
和
1 行删除
+27
-1
SamplesTest.java
h2/src/test/org/h2/test/jaqu/SamplesTest.java
+12
-1
Function.java
h2/src/tools/org/h2/jaqu/Function.java
+5
-0
Query.java
h2/src/tools/org/h2/jaqu/Query.java
+5
-0
QueryWhere.java
h2/src/tools/org/h2/jaqu/QueryWhere.java
+5
-0
没有找到文件。
h2/src/test/org/h2/test/jaqu/SamplesTest.java
浏览文件 @
d3609029
...
...
@@ -49,13 +49,14 @@ public class SamplesTest extends TestBase {
db
.
insertAll
(
Product
.
getProductList
());
db
.
insertAll
(
Customer
.
getCustomerList
());
db
.
insertAll
(
Order
.
getOrderList
());
// TODO
SUM,
MIN, MAX, LIKE, LIKE ESCAPE...
// TODO MIN, MAX, LIKE, LIKE ESCAPE...
// TODO +, -, *, /, ||, nested operations
// TODO nested AND/OR
// TODO NOT
// TODO DELETE: FROM ... DELETE?
// TODO UPDATE: FROM ... UPDATE?
// TODO SELECT UNION
testSum
();
testLength
();
testCount
();
testGroup
();
...
...
@@ -254,6 +255,16 @@ public class SamplesTest extends TestBase {
assertEquals
(
"[4, 5]"
,
s
);
}
private
void
testSum
()
throws
Exception
{
Product
p
=
new
Product
();
Integer
sum
=
db
.
from
(
p
).
selectFirst
(
sum
(
p
.
unitsInStock
));
assertEquals
(
323
,
sum
.
intValue
());
Double
sumPrice
=
db
.
from
(
p
).
selectFirst
(
sum
(
p
.
unitPrice
));
assertEquals
(
313.35
,
sumPrice
.
doubleValue
());
}
private
void
testCount
()
throws
Exception
{
long
count
=
db
.
from
(
new
Product
()).
selectCount
();
assertEquals
(
10
,
count
);
...
...
This diff is collapsed.
Click to expand it.
h2/src/tools/org/h2/jaqu/Function.java
浏览文件 @
d3609029
...
...
@@ -39,6 +39,11 @@ public class Function implements Token {
Utils
.
newObject
(
Integer
.
class
),
new
Function
(
"LENGTH"
,
x
));
}
public
static
<
T
extends
Number
>
T
sum
(
T
x
)
{
return
(
T
)
Db
.
registerToken
(
Utils
.
newObject
(
x
.
getClass
()),
new
Function
(
"SUM"
,
x
));
}
public
static
Long
count
(
Object
x
)
{
return
Db
.
registerToken
(
Utils
.
newObject
(
Long
.
class
),
new
Function
(
"COUNT"
,
x
));
...
...
This diff is collapsed.
Click to expand it.
h2/src/tools/org/h2/jaqu/Query.java
浏览文件 @
d3609029
...
...
@@ -62,6 +62,11 @@ public class Query<T> {
public
List
<
T
>
selectDistinct
()
{
return
select
(
true
);
}
public
<
X
,
Z
>
X
selectFirst
(
Z
x
)
{
List
<
X
>
list
=
(
List
<
X
>)
select
(
x
);
return
list
.
isEmpty
()
?
null
:
list
.
get
(
0
);
}
private
List
<
T
>
select
(
boolean
distinct
)
{
List
<
T
>
result
=
Utils
.
newArrayList
();
...
...
This diff is collapsed.
Click to expand it.
h2/src/tools/org/h2/jaqu/QueryWhere.java
浏览文件 @
d3609029
...
...
@@ -42,6 +42,11 @@ public class QueryWhere<T> {
return
(
List
<
X
>)
query
.
selectDistinct
(
x
);
}
public
<
X
,
Z
>
X
selectFirst
(
Z
x
)
{
List
<
X
>
list
=
(
List
<
X
>)
query
.
select
(
x
);
return
list
.
isEmpty
()
?
null
:
list
.
get
(
0
);
}
public
List
<
T
>
select
()
{
return
query
.
select
();
}
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论