Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
f6eb2bf3
提交
f6eb2bf3
authored
15 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Global temporary tables are now deleted when closing the database.
上级
09027986
master
noel-pr1
plus33-master
pr/267
stumc-Issue#576
version-1.4.198
version-1.4.197
version-1.4.196
version-1.4.195
version-1.4.194
version-1.4.193
version-1.4.192
version-1.4.191
version-1.4.190
version-1.4.188
version-1.4.187
version-1.4.186
version-1.4.185
version-1.4.184
version-1.4.183
version-1.4.182
version-1.4.181
version-1.4.178
version-1.4.177
version-1.3
version-1.2
version-1.1
version-1.0
无相关合并请求
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
32 行增加
和
1 行删除
+32
-1
Database.java
h2/src/main/org/h2/engine/Database.java
+5
-1
TestTempTables.java
h2/src/test/org/h2/test/db/TestTempTables.java
+27
-0
没有找到文件。
h2/src/main/org/h2/engine/Database.java
浏览文件 @
f6eb2bf3
...
...
@@ -1038,7 +1038,11 @@ public class Database implements DataHandler {
if
(
systemSession
!=
null
)
{
if
(
powerOffCount
!=
-
1
)
{
for
(
Table
table
:
getAllTablesAndViews
(
false
))
{
table
.
close
(
systemSession
);
if
(
table
.
isGlobalTemporary
())
{
table
.
removeChildrenAndResources
(
systemSession
);
}
else
{
table
.
close
(
systemSession
);
}
}
for
(
SchemaObject
obj
:
getAllSchemaObjects
(
DbObject
.
SEQUENCE
))
{
Sequence
sequence
=
(
Sequence
)
obj
;
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/db/TestTempTables.java
浏览文件 @
f6eb2bf3
...
...
@@ -6,10 +6,12 @@
*/
package
org
.
h2
.
test
.
db
;
import
java.io.File
;
import
java.sql.Connection
;
import
java.sql.ResultSet
;
import
java.sql.SQLException
;
import
java.sql.Statement
;
import
org.h2.engine.Constants
;
import
org.h2.test.TestBase
;
/**
...
...
@@ -28,6 +30,7 @@ public class TestTempTables extends TestBase {
public
void
test
()
throws
SQLException
{
deleteDb
(
"tempTables"
);
testDeleteGlobalTempTableWhenClosing
();
Connection
c1
=
getConnection
(
"tempTables"
);
testAlter
(
c1
);
Connection
c2
=
getConnection
(
"tempTables"
);
...
...
@@ -39,6 +42,30 @@ public class TestTempTables extends TestBase {
deleteDb
(
"tempTables"
);
}
private
void
testDeleteGlobalTempTableWhenClosing
()
throws
SQLException
{
if
(
config
.
memory
)
{
return
;
}
deleteDb
(
"tempTables"
);
Connection
conn
=
getConnection
(
"tempTables"
);
Statement
stat
=
conn
.
createStatement
();
stat
.
execute
(
"create global temporary table test(id int, data varchar)"
);
stat
.
execute
(
"insert into test select x, space(1000) from system_range(1, 1000)"
);
stat
.
execute
(
"shutdown compact"
);
try
{
conn
.
close
();
}
catch
(
SQLException
e
)
{
// expected
}
String
dbName
=
baseDir
+
"/tempTables"
+
Constants
.
SUFFIX_PAGE_FILE
;
long
before
=
new
File
(
dbName
).
length
();
assertTrue
(
before
>
0
);
conn
=
getConnection
(
"tempTables"
);
conn
.
close
();
long
after
=
new
File
(
dbName
).
length
();
assertEquals
(
after
,
before
);
}
private
void
testAlter
(
Connection
conn
)
throws
SQLException
{
Statement
stat
;
stat
=
conn
.
createStatement
();
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论