Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
455c15cb
提交
455c15cb
authored
15 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
The Recover tool did not work with .data.db files of the wrong size.
上级
153b346b
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
36 行增加
和
1 行删除
+36
-1
Recover.java
h2/src/main/org/h2/tools/Recover.java
+36
-1
没有找到文件。
h2/src/main/org/h2/tools/Recover.java
浏览文件 @
455c15cb
...
...
@@ -10,6 +10,7 @@ import java.io.BufferedInputStream;
import
java.io.BufferedReader
;
import
java.io.ByteArrayInputStream
;
import
java.io.DataInputStream
;
import
java.io.EOFException
;
import
java.io.IOException
;
import
java.io.InputStream
;
import
java.io.InputStreamReader
;
...
...
@@ -40,8 +41,10 @@ import org.h2.store.DiskFile;
import
org.h2.store.FileLister
;
import
org.h2.store.FileStore
;
import
org.h2.store.FileStoreInputStream
;
import
org.h2.store.PageFreeList
;
import
org.h2.store.PageLog
;
import
org.h2.store.PageStore
;
import
org.h2.util.BitField
;
import
org.h2.util.ByteUtils
;
import
org.h2.util.FileUtils
;
import
org.h2.util.IOUtils
;
...
...
@@ -719,6 +722,7 @@ public class Recover extends Tool implements DataHandler {
setDatabaseName
(
fileName
.
substring
(
0
,
fileName
.
length
()
-
Constants
.
SUFFIX_PAGE_FILE
.
length
()));
FileStore
store
=
null
;
PrintWriter
writer
=
null
;
int
emptyPages
=
0
;
try
{
writer
=
getWriter
(
fileName
,
".sql"
);
writer
.
println
(
"CREATE ALIAS IF NOT EXISTS READ_CLOB FOR \""
+
this
.
getClass
().
getName
()
+
".readClob\";"
);
...
...
@@ -778,6 +782,7 @@ public class Recover extends Tool implements DataHandler {
" firstDataPage: "
+
logFirstDataPage
);
s
=
DataPage
.
create
(
this
,
pageSize
);
int
free
=
0
;
for
(
long
page
=
3
;
page
<
pageCount
;
page
++)
{
s
=
DataPage
.
create
(
this
,
pageSize
);
store
.
seek
(
page
*
pageSize
);
...
...
@@ -789,6 +794,7 @@ public class Recover extends Tool implements DataHandler {
if
(
parentPageId
!=
0
)
{
writer
.
println
(
"-- ERROR empty page with parent: "
+
parentPageId
);
}
emptyPages
++;
continue
;
}
boolean
last
=
(
type
&
Page
.
FLAG_LAST
)
!=
0
;
...
...
@@ -820,6 +826,7 @@ public class Recover extends Tool implements DataHandler {
break
;
case
Page
.
TYPE_FREE_LIST
:
writer
.
println
(
"-- page "
+
page
+
": free list "
+
(
last
?
"(last)"
:
""
));
free
+=
dumpPageFreeList
(
writer
,
s
,
pageSize
,
page
);
break
;
case
Page
.
TYPE_STREAM_TRUNK
:
writer
.
println
(
"-- page "
+
page
+
": log trunk"
);
...
...
@@ -832,8 +839,13 @@ public class Recover extends Tool implements DataHandler {
break
;
}
}
writer
.
println
(
"-- page count: "
+
pageCount
+
" empty: "
+
emptyPages
+
" free: "
+
free
);
writeSchema
(
writer
);
dumpPageLogStream
(
writer
,
store
,
logFirstTrunkPage
,
logFirstDataPage
,
pageSize
);
try
{
dumpPageLogStream
(
writer
,
store
,
logFirstTrunkPage
,
logFirstDataPage
,
pageSize
);
}
catch
(
EOFException
e
)
{
// ignore
}
writer
.
close
();
}
catch
(
Throwable
e
)
{
writeError
(
writer
,
e
);
...
...
@@ -1040,6 +1052,29 @@ public class Recover extends Tool implements DataHandler {
writer
.
println
(
"-- ["
+
entryCount
+
"] child: "
+
children
[
entryCount
]
+
" rowCount: "
+
rowCount
);
}
private
int
dumpPageFreeList
(
PrintWriter
writer
,
DataPage
s
,
int
pageSize
,
long
pageId
)
{
int
pagesAddressed
=
PageFreeList
.
getPagesAddressed
(
pageSize
);
BitField
used
=
new
BitField
();
for
(
int
i
=
0
;
i
<
pagesAddressed
;
i
+=
8
)
{
used
.
setByte
(
i
,
s
.
readByte
());
}
int
free
=
0
;
for
(
int
i
=
0
;
i
<
pagesAddressed
;
i
++)
{
if
(
i
%
80
==
0
)
{
if
(
i
>
0
)
{
writer
.
println
();
}
writer
.
print
(
"-- "
+
(
i
+
pageId
)
+
" "
);
}
writer
.
print
(
used
.
get
(
i
)
?
'1'
:
'0'
);
if
(!
used
.
get
(
i
))
{
free
++;
}
}
writer
.
println
();
return
free
;
}
private
void
dumpPageBtreeLeaf
(
PrintWriter
writer
,
DataPage
s
)
{
int
entryCount
=
s
.
readShortInt
();
int
[]
offsets
=
new
int
[
entryCount
];
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论