Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
47c6a50f
提交
47c6a50f
authored
1月 20, 2009
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
New experimental page store.
上级
80fcd4a5
隐藏空白字符变更
内嵌
并排
正在显示
12 个修改的文件
包含
184 行增加
和
114 行删除
+184
-114
BackupCommand.java
h2/src/main/org/h2/command/dml/BackupCommand.java
+23
-1
PageDataLeaf.java
h2/src/main/org/h2/index/PageDataLeaf.java
+5
-1
PageDataNode.java
h2/src/main/org/h2/index/PageDataNode.java
+19
-35
PageScanIndex.java
h2/src/main/org/h2/index/PageScanIndex.java
+25
-14
Trace.java
h2/src/main/org/h2/message/Trace.java
+5
-0
TraceSystem.java
h2/src/main/org/h2/message/TraceSystem.java
+3
-1
FileLister.java
h2/src/main/org/h2/store/FileLister.java
+9
-2
PageInputStream.java
h2/src/main/org/h2/store/PageInputStream.java
+0
-5
PageLog.java
h2/src/main/org/h2/store/PageLog.java
+28
-15
PageOutputStream.java
h2/src/main/org/h2/store/PageOutputStream.java
+8
-32
PageStore.java
h2/src/main/org/h2/store/PageStore.java
+58
-7
Restore.java
h2/src/main/org/h2/tools/Restore.java
+1
-1
没有找到文件。
h2/src/main/org/h2/command/dml/BackupCommand.java
浏览文件 @
47c6a50f
...
@@ -17,6 +17,7 @@ import java.util.zip.ZipOutputStream;
...
@@ -17,6 +17,7 @@ import java.util.zip.ZipOutputStream;
import
org.h2.api.DatabaseEventListener
;
import
org.h2.api.DatabaseEventListener
;
import
org.h2.command.Prepared
;
import
org.h2.command.Prepared
;
import
org.h2.constant.ErrorCode
;
import
org.h2.constant.ErrorCode
;
import
org.h2.constant.SysProperties
;
import
org.h2.engine.Constants
;
import
org.h2.engine.Constants
;
import
org.h2.engine.Database
;
import
org.h2.engine.Database
;
import
org.h2.engine.Session
;
import
org.h2.engine.Session
;
...
@@ -27,6 +28,7 @@ import org.h2.message.Message;
...
@@ -27,6 +28,7 @@ import org.h2.message.Message;
import
org.h2.result.LocalResult
;
import
org.h2.result.LocalResult
;
import
org.h2.store.DiskFile
;
import
org.h2.store.DiskFile
;
import
org.h2.store.FileLister
;
import
org.h2.store.FileLister
;
import
org.h2.store.PageStore
;
import
org.h2.util.FileUtils
;
import
org.h2.util.FileUtils
;
import
org.h2.util.IOUtils
;
import
org.h2.util.IOUtils
;
import
org.h2.util.ObjectArray
;
import
org.h2.util.ObjectArray
;
...
@@ -71,12 +73,16 @@ public class BackupCommand extends Prepared {
...
@@ -71,12 +73,16 @@ public class BackupCommand extends Prepared {
String
fn
=
db
.
getName
()
+
Constants
.
SUFFIX_DATA_FILE
;
String
fn
=
db
.
getName
()
+
Constants
.
SUFFIX_DATA_FILE
;
backupDiskFile
(
out
,
fn
,
db
.
getDataFile
());
backupDiskFile
(
out
,
fn
,
db
.
getDataFile
());
fn
=
db
.
getName
()
+
Constants
.
SUFFIX_INDEX_FILE
;
fn
=
db
.
getName
()
+
Constants
.
SUFFIX_INDEX_FILE
;
String
base
=
FileUtils
.
getParent
(
fn
);
backupDiskFile
(
out
,
fn
,
db
.
getIndexFile
());
backupDiskFile
(
out
,
fn
,
db
.
getIndexFile
());
if
(
SysProperties
.
PAGE_STORE
)
{
fn
=
db
.
getName
()
+
Constants
.
SUFFIX_PAGE_FILE
;
backupPageStore
(
out
,
fn
,
db
.
getPageStore
());
}
ObjectArray
list
=
log
.
getActiveLogFiles
();
ObjectArray
list
=
log
.
getActiveLogFiles
();
int
max
=
list
.
size
();
int
max
=
list
.
size
();
// synchronize on the database, to avoid concurrent temp file
// synchronize on the database, to avoid concurrent temp file
// creation / deletion / backup
// creation / deletion / backup
String
base
=
FileUtils
.
getParent
(
fn
);
synchronized
(
db
.
getLobSyncObject
())
{
synchronized
(
db
.
getLobSyncObject
())
{
for
(
int
i
=
0
;
i
<
list
.
size
();
i
++)
{
for
(
int
i
=
0
;
i
<
list
.
size
();
i
++)
{
LogFile
lf
=
(
LogFile
)
list
.
get
(
i
);
LogFile
lf
=
(
LogFile
)
list
.
get
(
i
);
...
@@ -104,6 +110,22 @@ public class BackupCommand extends Prepared {
...
@@ -104,6 +110,22 @@ public class BackupCommand extends Prepared {
}
}
}
}
private
void
backupPageStore
(
ZipOutputStream
out
,
String
fileName
,
PageStore
store
)
throws
SQLException
,
IOException
{
Database
db
=
session
.
getDatabase
();
fileName
=
FileUtils
.
getFileName
(
fileName
);
out
.
putNextEntry
(
new
ZipEntry
(
fileName
));
int
max
=
store
.
getPageCount
();
int
pos
=
0
;
while
(
true
)
{
pos
=
store
.
copyDirect
(
pos
,
out
);
if
(
pos
<
0
)
{
break
;
}
db
.
setProgress
(
DatabaseEventListener
.
STATE_BACKUP_FILE
,
fileName
,
pos
,
max
);
}
out
.
closeEntry
();
}
private
void
backupDiskFile
(
ZipOutputStream
out
,
String
fileName
,
DiskFile
file
)
throws
SQLException
,
IOException
{
private
void
backupDiskFile
(
ZipOutputStream
out
,
String
fileName
,
DiskFile
file
)
throws
SQLException
,
IOException
{
Database
db
=
session
.
getDatabase
();
Database
db
=
session
.
getDatabase
();
fileName
=
FileUtils
.
getFileName
(
fileName
);
fileName
=
FileUtils
.
getFileName
(
fileName
);
...
...
h2/src/main/org/h2/index/PageDataLeaf.java
浏览文件 @
47c6a50f
...
@@ -182,6 +182,10 @@ class PageDataLeaf extends PageData {
...
@@ -182,6 +182,10 @@ class PageDataLeaf extends PageData {
* @return the row
* @return the row
*/
*/
Row
getRowAt
(
int
at
)
throws
SQLException
{
Row
getRowAt
(
int
at
)
throws
SQLException
{
int
test
;
if
(
rows
==
null
)
{
System
.
out
.
println
(
"stop"
);
}
Row
r
=
rows
[
at
];
Row
r
=
rows
[
at
];
if
(
r
==
null
)
{
if
(
r
==
null
)
{
if
(
firstOverflowPageId
!=
0
)
{
if
(
firstOverflowPageId
!=
0
)
{
...
@@ -262,7 +266,7 @@ class PageDataLeaf extends PageData {
...
@@ -262,7 +266,7 @@ class PageDataLeaf extends PageData {
boolean
remove
(
int
key
)
throws
SQLException
{
boolean
remove
(
int
key
)
throws
SQLException
{
int
i
=
find
(
key
);
int
i
=
find
(
key
);
if
(
keys
[
i
]
!=
key
)
{
if
(
keys
[
i
]
!=
key
)
{
throw
Message
.
getSQLException
(
ErrorCode
.
ROW_NOT_FOUND_WHEN_DELETING_1
,
index
.
getSQL
());
throw
Message
.
getSQLException
(
ErrorCode
.
ROW_NOT_FOUND_WHEN_DELETING_1
,
index
.
getSQL
()
+
": "
+
key
);
}
}
if
(
entryCount
==
1
)
{
if
(
entryCount
==
1
)
{
return
true
;
return
true
;
...
...
h2/src/main/org/h2/index/PageDataNode.java
浏览文件 @
47c6a50f
...
@@ -137,20 +137,6 @@ class PageDataNode extends PageData {
...
@@ -137,20 +137,6 @@ class PageDataNode extends PageData {
}
}
}
}
private
void
removeChild
(
int
x
)
{
int
[]
newKeys
=
new
int
[
entryCount
-
1
];
int
[]
newChildPageIds
=
new
int
[
entryCount
];
System
.
arraycopy
(
keys
,
0
,
newKeys
,
0
,
x
);
System
.
arraycopy
(
childPageIds
,
0
,
newChildPageIds
,
0
,
x
+
1
);
if
(
x
<
entryCount
)
{
System
.
arraycopy
(
keys
,
x
+
1
,
newKeys
,
x
,
entryCount
-
x
-
1
);
System
.
arraycopy
(
childPageIds
,
x
+
1
,
newChildPageIds
,
x
,
entryCount
-
x
);
}
keys
=
newKeys
;
childPageIds
=
newChildPageIds
;
entryCount
--;
}
/**
/**
* Initialize the page.
* Initialize the page.
*
*
...
@@ -194,23 +180,6 @@ class PageDataNode extends PageData {
...
@@ -194,23 +180,6 @@ class PageDataNode extends PageData {
return
index
.
getPage
(
child
).
getFirstLeaf
();
return
index
.
getPage
(
child
).
getFirstLeaf
();
}
}
private
void
removeRow
(
int
i
)
throws
SQLException
{
entryCount
--;
if
(
entryCount
<=
0
)
{
Message
.
throwInternalError
();
}
int
[]
newKeys
=
new
int
[
entryCount
];
int
[]
newChildPageIds
=
new
int
[
entryCount
+
1
];
System
.
arraycopy
(
keys
,
0
,
newKeys
,
0
,
Math
.
min
(
entryCount
,
i
));
System
.
arraycopy
(
childPageIds
,
0
,
newChildPageIds
,
0
,
i
);
if
(
entryCount
>
i
)
{
System
.
arraycopy
(
keys
,
i
+
1
,
newKeys
,
i
,
entryCount
-
i
);
}
System
.
arraycopy
(
childPageIds
,
i
+
1
,
newChildPageIds
,
i
,
entryCount
-
i
+
1
);
keys
=
newKeys
;
childPageIds
=
newChildPageIds
;
}
boolean
remove
(
int
key
)
throws
SQLException
{
boolean
remove
(
int
key
)
throws
SQLException
{
int
at
=
find
(
key
);
int
at
=
find
(
key
);
// merge is not implemented to allow concurrent usage of btrees
// merge is not implemented to allow concurrent usage of btrees
...
@@ -224,13 +193,11 @@ class PageDataNode extends PageData {
...
@@ -224,13 +193,11 @@ class PageDataNode extends PageData {
}
}
// this child is now empty
// this child is now empty
index
.
getPageStore
().
freePage
(
page
.
getPageId
());
index
.
getPageStore
().
freePage
(
page
.
getPageId
());
if
(
entryCount
==
0
)
{
if
(
entryCount
<
1
)
{
// no more children - this page is empty as well
// no more children - this page is empty as well
// it can't be the root otherwise the index would have been
// truncated
return
true
;
return
true
;
}
}
remove
Row
(
at
);
remove
Child
(
at
);
index
.
getPageStore
().
updateRecord
(
this
,
data
);
index
.
getPageStore
().
updateRecord
(
this
,
data
);
return
false
;
return
false
;
}
}
...
@@ -288,4 +255,21 @@ class PageDataNode extends PageData {
...
@@ -288,4 +255,21 @@ class PageDataNode extends PageData {
index
.
getPageStore
().
writePage
(
getPos
(),
data
);
index
.
getPageStore
().
writePage
(
getPos
(),
data
);
}
}
private
void
removeChild
(
int
i
)
throws
SQLException
{
entryCount
--;
if
(
entryCount
<
0
)
{
Message
.
throwInternalError
();
}
int
[]
newKeys
=
new
int
[
entryCount
];
int
[]
newChildPageIds
=
new
int
[
entryCount
+
1
];
System
.
arraycopy
(
keys
,
0
,
newKeys
,
0
,
Math
.
min
(
entryCount
,
i
));
System
.
arraycopy
(
childPageIds
,
0
,
newChildPageIds
,
0
,
i
);
if
(
entryCount
>
i
)
{
System
.
arraycopy
(
keys
,
i
+
1
,
newKeys
,
i
,
entryCount
-
i
);
}
System
.
arraycopy
(
childPageIds
,
i
+
1
,
newChildPageIds
,
i
,
entryCount
-
i
+
1
);
keys
=
newKeys
;
childPageIds
=
newChildPageIds
;
}
}
}
h2/src/main/org/h2/index/PageScanIndex.java
浏览文件 @
47c6a50f
...
@@ -41,6 +41,8 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -41,6 +41,8 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
// TODO file position, content checksums
// TODO file position, content checksums
// TODO completely re-use keys of deleted rows
// TODO completely re-use keys of deleted rows
// TODO remove Database.objectIds
// TODO remove Database.objectIds
// TODO detect circles in linked lists
// (input stream, free list, extend pages...)
private
int
lastKey
;
private
int
lastKey
;
private
long
rowCount
;
private
long
rowCount
;
...
@@ -48,6 +50,7 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -48,6 +50,7 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
public
PageScanIndex
(
TableData
table
,
int
id
,
IndexColumn
[]
columns
,
IndexType
indexType
,
int
headPos
)
throws
SQLException
{
public
PageScanIndex
(
TableData
table
,
int
id
,
IndexColumn
[]
columns
,
IndexType
indexType
,
int
headPos
)
throws
SQLException
{
initBaseIndex
(
table
,
id
,
table
.
getName
()
+
"_TABLE_SCAN"
,
columns
,
indexType
);
initBaseIndex
(
table
,
id
,
table
.
getName
()
+
"_TABLE_SCAN"
,
columns
,
indexType
);
// trace.setLevel(TraceSystem.DEBUG);
if
(
database
.
isMultiVersion
())
{
if
(
database
.
isMultiVersion
())
{
int
todoMvcc
;
int
todoMvcc
;
}
}
...
@@ -72,7 +75,9 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -72,7 +75,9 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
int
reuseKeysIfManyDeleted
;
int
reuseKeysIfManyDeleted
;
}
}
this
.
headPos
=
headPos
;
this
.
headPos
=
headPos
;
trace
(
"open "
+
rowCount
);
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"open "
+
rowCount
);
}
table
.
setRowCount
(
rowCount
);
table
.
setRowCount
(
rowCount
);
}
}
...
@@ -82,14 +87,18 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -82,14 +87,18 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
public
void
add
(
Session
session
,
Row
row
)
throws
SQLException
{
public
void
add
(
Session
session
,
Row
row
)
throws
SQLException
{
row
.
setPos
(++
lastKey
);
row
.
setPos
(++
lastKey
);
trace
(
"add "
+
row
.
getPos
());
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"add "
+
row
.
getPos
());
}
while
(
true
)
{
while
(
true
)
{
PageData
root
=
getPage
(
headPos
);
PageData
root
=
getPage
(
headPos
);
int
splitPoint
=
root
.
addRow
(
row
);
int
splitPoint
=
root
.
addRow
(
row
);
if
(
splitPoint
==
0
)
{
if
(
splitPoint
==
0
)
{
break
;
break
;
}
}
trace
(
"split "
+
splitPoint
);
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"split "
+
splitPoint
);
}
int
pivot
=
root
.
getKey
(
splitPoint
-
1
);
int
pivot
=
root
.
getKey
(
splitPoint
-
1
);
PageData
page1
=
root
;
PageData
page1
=
root
;
PageData
page2
=
root
.
split
(
splitPoint
);
PageData
page2
=
root
.
split
(
splitPoint
);
...
@@ -147,7 +156,9 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -147,7 +156,9 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
}
}
public
void
close
(
Session
session
)
throws
SQLException
{
public
void
close
(
Session
session
)
throws
SQLException
{
trace
(
"close"
);
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"close"
);
}
int
writeRowCount
;
int
writeRowCount
;
}
}
...
@@ -170,10 +181,13 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -170,10 +181,13 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
}
}
public
void
remove
(
Session
session
,
Row
row
)
throws
SQLException
{
public
void
remove
(
Session
session
,
Row
row
)
throws
SQLException
{
trace
(
"remove "
+
row
.
getPos
());
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"remove "
+
row
.
getPos
());
}
int
invalidateRowCount
;
int
invalidateRowCount
;
// setChanged(session);
// setChanged(session);
if
(
rowCount
==
1
)
{
if
(
rowCount
==
1
)
{
int
todoMaybeImprove
;
truncate
(
session
);
truncate
(
session
);
}
else
{
}
else
{
int
key
=
row
.
getPos
();
int
key
=
row
.
getPos
();
...
@@ -189,12 +203,16 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -189,12 +203,16 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
}
}
public
void
remove
(
Session
session
)
throws
SQLException
{
public
void
remove
(
Session
session
)
throws
SQLException
{
trace
(
"remove"
);
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"remove"
);
}
int
todo
;
int
todo
;
}
}
public
void
truncate
(
Session
session
)
throws
SQLException
{
public
void
truncate
(
Session
session
)
throws
SQLException
{
trace
(
"truncate"
);
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"truncate"
);
}
store
.
removeRecord
(
headPos
);
store
.
removeRecord
(
headPos
);
int
todoLogOldData
;
int
todoLogOldData
;
int
freePages
;
int
freePages
;
...
@@ -239,13 +257,6 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
...
@@ -239,13 +257,6 @@ public class PageScanIndex extends BaseIndex implements RowIndex {
return
null
;
return
null
;
}
}
private
void
trace
(
String
message
)
{
int
slowEvenIfNotEnabled
;
if
(
headPos
!=
1
)
{
// System.out.println(message);
}
}
public
int
getColumnIndex
(
Column
col
)
{
public
int
getColumnIndex
(
Column
col
)
{
// the scan index cannot use any columns
// the scan index cannot use any columns
// TODO it can if there is an INT primary key
// TODO it can if there is an INT primary key
...
...
h2/src/main/org/h2/message/Trace.java
浏览文件 @
47c6a50f
...
@@ -94,6 +94,11 @@ public class Trace {
...
@@ -94,6 +94,11 @@ public class Trace {
*/
*/
public
static
final
String
USER
=
"user"
;
public
static
final
String
USER
=
"user"
;
/**
* The trace module name for the page store.
*/
public
static
final
String
PAGE_STORE
=
"pageStore"
;
private
TraceWriter
traceWriter
;
private
TraceWriter
traceWriter
;
private
String
module
;
private
String
module
;
private
String
lineSeparator
;
private
String
lineSeparator
;
...
...
h2/src/main/org/h2/message/TraceSystem.java
浏览文件 @
47c6a50f
...
@@ -216,7 +216,9 @@ public class TraceSystem implements TraceWriter {
...
@@ -216,7 +216,9 @@ public class TraceSystem implements TraceWriter {
}
}
public
void
write
(
int
level
,
String
module
,
String
s
,
Throwable
t
)
{
public
void
write
(
int
level
,
String
module
,
String
s
,
Throwable
t
)
{
if
(
level
<=
levelSystemOut
)
{
if
(
level
<=
levelSystemOut
||
level
>
this
.
level
)
{
// level <= levelSystemOut: the system out level is set higher
// level > this.level: the level for this module is set higher
System
.
out
.
println
(
format
(
module
,
s
));
System
.
out
.
println
(
format
(
module
,
s
));
if
(
t
!=
null
&&
levelSystemOut
==
DEBUG
)
{
if
(
t
!=
null
&&
levelSystemOut
==
DEBUG
)
{
t
.
printStackTrace
();
t
.
printStackTrace
();
...
...
h2/src/main/org/h2/store/FileLister.java
浏览文件 @
47c6a50f
...
@@ -9,6 +9,7 @@ package org.h2.store;
...
@@ -9,6 +9,7 @@ package org.h2.store;
import
java.sql.SQLException
;
import
java.sql.SQLException
;
import
java.util.ArrayList
;
import
java.util.ArrayList
;
import
org.h2.constant.SysProperties
;
import
org.h2.engine.Constants
;
import
org.h2.engine.Constants
;
import
org.h2.util.FileUtils
;
import
org.h2.util.FileUtils
;
...
@@ -29,8 +30,14 @@ public class FileLister {
...
@@ -29,8 +30,14 @@ public class FileLister {
* @return the database name or null
* @return the database name or null
*/
*/
public
static
String
getDatabaseNameFromFileName
(
String
fileName
)
{
public
static
String
getDatabaseNameFromFileName
(
String
fileName
)
{
if
(
fileName
.
endsWith
(
Constants
.
SUFFIX_DATA_FILE
))
{
if
(
SysProperties
.
PAGE_STORE
)
{
return
fileName
.
substring
(
0
,
fileName
.
length
()
-
Constants
.
SUFFIX_DATA_FILE
.
length
());
if
(
fileName
.
endsWith
(
Constants
.
SUFFIX_PAGE_FILE
))
{
return
fileName
.
substring
(
0
,
fileName
.
length
()
-
Constants
.
SUFFIX_PAGE_FILE
.
length
());
}
}
else
{
if
(
fileName
.
endsWith
(
Constants
.
SUFFIX_DATA_FILE
))
{
return
fileName
.
substring
(
0
,
fileName
.
length
()
-
Constants
.
SUFFIX_DATA_FILE
.
length
());
}
}
}
return
null
;
return
null
;
}
}
...
...
h2/src/main/org/h2/store/PageInputStream.java
浏览文件 @
47c6a50f
...
@@ -64,9 +64,6 @@ public class PageInputStream extends InputStream {
...
@@ -64,9 +64,6 @@ public class PageInputStream extends InputStream {
off
+=
r
;
off
+=
r
;
len
-=
r
;
len
-=
r
;
}
}
int
test
;
if
(
read
==
0
)
System
.
out
.
println
(
"stop"
);
return
read
==
0
?
-
1
:
read
;
return
read
==
0
?
-
1
:
read
;
}
}
...
@@ -110,8 +107,6 @@ System.out.println("stop");
...
@@ -110,8 +107,6 @@ System.out.println("stop");
nextPage
=
page
.
readInt
();
nextPage
=
page
.
readInt
();
remaining
=
store
.
getPageSize
()
-
page
.
length
();
remaining
=
store
.
getPageSize
()
-
page
.
length
();
}
}
int
test
;
System
.
out
.
println
(
" pageIn.read "
+
page
+
" next:"
+
nextPage
);
}
catch
(
SQLException
e
)
{
}
catch
(
SQLException
e
)
{
throw
Message
.
convertToIOException
(
e
);
throw
Message
.
convertToIOException
(
e
);
}
}
...
...
h2/src/main/org/h2/store/PageLog.java
浏览文件 @
47c6a50f
...
@@ -56,7 +56,7 @@ public class PageLog {
...
@@ -56,7 +56,7 @@ public class PageLog {
* must be run first.
* must be run first.
*/
*/
void
openForWriting
()
{
void
openForWriting
()
{
trace
.
debug
(
"openForWriting"
);
trace
.
debug
(
"
log
openForWriting"
);
pageOut
=
new
PageOutputStream
(
store
,
0
,
firstPage
,
Page
.
TYPE_LOG
);
pageOut
=
new
PageOutputStream
(
store
,
0
,
firstPage
,
Page
.
TYPE_LOG
);
out
=
new
DataOutputStream
(
pageOut
);
out
=
new
DataOutputStream
(
pageOut
);
}
}
...
@@ -69,7 +69,7 @@ public class PageLog {
...
@@ -69,7 +69,7 @@ public class PageLog {
* @param undo true if the undo step should be run
* @param undo true if the undo step should be run
*/
*/
public
void
recover
(
boolean
undo
)
throws
SQLException
{
public
void
recover
(
boolean
undo
)
throws
SQLException
{
trace
.
debug
(
"recover"
);
trace
.
debug
(
"
log
recover"
);
DataInputStream
in
=
new
DataInputStream
(
new
PageInputStream
(
store
,
0
,
firstPage
,
Page
.
TYPE_LOG
));
DataInputStream
in
=
new
DataInputStream
(
new
PageInputStream
(
store
,
0
,
firstPage
,
Page
.
TYPE_LOG
));
DataPage
data
=
store
.
createDataPage
();
DataPage
data
=
store
.
createDataPage
();
try
{
try
{
...
@@ -85,6 +85,9 @@ public class PageLog {
...
@@ -85,6 +85,9 @@ public class PageLog {
int
pageId
=
in
.
readInt
();
int
pageId
=
in
.
readInt
();
in
.
read
(
data
.
getBytes
(),
0
,
store
.
getPageSize
());
in
.
read
(
data
.
getBytes
(),
0
,
store
.
getPageSize
());
if
(
undo
)
{
if
(
undo
)
{
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"log write "
+
pageId
);
}
store
.
writePage
(
pageId
,
data
);
store
.
writePage
(
pageId
,
data
);
}
}
}
else
if
(
x
==
ADD
||
x
==
REMOVE
)
{
}
else
if
(
x
==
ADD
||
x
==
REMOVE
)
{
...
@@ -93,6 +96,9 @@ public class PageLog {
...
@@ -93,6 +96,9 @@ public class PageLog {
Row
row
=
readRow
(
in
);
Row
row
=
readRow
(
in
);
Database
db
=
store
.
getDatabase
();
Database
db
=
store
.
getDatabase
();
if
(!
undo
)
{
if
(!
undo
)
{
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"log redo "
+
(
x
==
ADD
?
"+"
:
"-"
)
+
" "
+
row
);
}
db
.
redo
(
tableId
,
row
,
x
==
ADD
);
db
.
redo
(
tableId
,
row
,
x
==
ADD
);
}
}
}
else
if
(
x
==
COMMIT
)
{
}
else
if
(
x
==
COMMIT
)
{
...
@@ -102,15 +108,16 @@ public class PageLog {
...
@@ -102,15 +108,16 @@ public class PageLog {
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
int
todoOnlyIOExceptionAndSQLException
;
int
todoOnlyIOExceptionAndSQLException
;
int
todoSomeExceptionAreOkSomeNot
;
int
todoSomeExceptionAreOkSomeNot
;
//e.printStackTrace();
trace
.
debug
(
"log recovery stopped: "
+
e
.
toString
());
trace
.
debug
(
"recovery stopped: "
+
e
.
toString
());
}
finally
{
}
finally
{
recoveryRunning
=
false
;
recoveryRunning
=
false
;
}
}
trace
.
debug
(
"log recover done"
);
int
todoDeleteAfterRecovering
;
int
todoDeleteAfterRecovering
;
}
}
private
Row
readRow
(
DataInputStream
in
)
throws
IOException
,
SQLException
{
private
Row
readRow
(
DataInputStream
in
)
throws
IOException
,
SQLException
{
int
pos
=
in
.
readInt
();
int
len
=
in
.
readInt
();
int
len
=
in
.
readInt
();
data
.
reset
();
data
.
reset
();
data
.
checkCapacity
(
len
);
data
.
checkCapacity
(
len
);
...
@@ -122,6 +129,7 @@ public class PageLog {
...
@@ -122,6 +129,7 @@ public class PageLog {
}
}
int
todoTableDataReadRowWithMemory
;
int
todoTableDataReadRowWithMemory
;
Row
row
=
new
Row
(
values
,
0
);
Row
row
=
new
Row
(
values
,
0
);
row
.
setPos
(
pos
);
return
row
;
return
row
;
}
}
...
@@ -153,7 +161,7 @@ public class PageLog {
...
@@ -153,7 +161,7 @@ public class PageLog {
*/
*/
public
void
commit
(
Session
session
)
throws
SQLException
{
public
void
commit
(
Session
session
)
throws
SQLException
{
try
{
try
{
trace
.
debug
(
"commit"
);
trace
.
debug
(
"
log
commit"
);
out
.
write
(
COMMIT
);
out
.
write
(
COMMIT
);
out
.
writeInt
(
session
.
getId
());
out
.
writeInt
(
session
.
getId
());
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
...
@@ -175,13 +183,15 @@ public class PageLog {
...
@@ -175,13 +183,15 @@ public class PageLog {
return
;
return
;
}
}
if
(
trace
.
isDebugEnabled
())
{
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
((
add
?
"+"
:
"-"
)
+
" table:"
+
tableId
+
trace
.
debug
(
"log "
+
(
add
?
"+"
:
"-"
)
+
" table:"
+
tableId
+
" remaining:"
+
pageOut
.
getRemainingBytes
()
+
" row:"
+
row
);
" remaining:"
+
pageOut
.
getRemainingBytes
()
+
" row:"
+
row
);
}
}
out
.
write
(
add
?
ADD
:
REMOVE
);
out
.
write
(
add
?
ADD
:
REMOVE
);
out
.
writeInt
(
session
.
getId
());
out
.
writeInt
(
session
.
getId
());
out
.
writeInt
(
tableId
);
out
.
writeInt
(
tableId
);
out
.
writeInt
(
row
.
getPos
());
data
.
reset
();
data
.
reset
();
int
todoWriteIntoOutputDirectly
;
row
.
write
(
data
);
row
.
write
(
data
);
out
.
writeInt
(
data
.
length
());
out
.
writeInt
(
data
.
length
());
out
.
write
(
data
.
getBytes
(),
0
,
data
.
length
());
out
.
write
(
data
.
getBytes
(),
0
,
data
.
length
());
...
@@ -195,8 +205,10 @@ public class PageLog {
...
@@ -195,8 +205,10 @@ public class PageLog {
*/
*/
void
reopen
()
throws
SQLException
{
void
reopen
()
throws
SQLException
{
try
{
try
{
trace
.
debug
(
"log reopen"
);
out
.
close
();
out
.
close
();
openForWriting
();
openForWriting
();
flush
();
int
todoDeleteOrReUsePages
;
int
todoDeleteOrReUsePages
;
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
Message
.
convertIOException
(
e
,
null
);
throw
Message
.
convertIOException
(
e
,
null
);
...
@@ -208,12 +220,13 @@ public class PageLog {
...
@@ -208,12 +220,13 @@ public class PageLog {
*/
*/
public
void
flush
()
throws
SQLException
{
public
void
flush
()
throws
SQLException
{
try
{
try
{
trace
.
debug
(
"flush"
);
trace
.
debug
(
"
log
flush"
);
out
.
flush
();
out
.
flush
();
int
filler
=
pageOut
.
getRemainingBytes
();
int
filler
=
pageOut
.
getRemainingBytes
();
for
(
int
i
=
0
;
i
<
filler
;
i
++)
{
for
(
int
i
=
0
;
i
<
filler
;
i
++)
{
out
.
writeByte
(
NO_OP
);
out
.
writeByte
(
NO_OP
);
}
}
out
.
flush
();
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
Message
.
convertIOException
(
e
,
null
);
throw
Message
.
convertIOException
(
e
,
null
);
}
}
...
@@ -222,13 +235,13 @@ public class PageLog {
...
@@ -222,13 +235,13 @@ public class PageLog {
/**
/**
* Flush and close the log.
* Flush and close the log.
*/
*/
public
void
close
()
throws
SQLException
{
//
public void close() throws SQLException {
try
{
//
try {
trace
.
debug
(
"
close"
);
// trace.debug("log
close");
out
.
close
();
//
out.close();
}
catch
(
IOException
e
)
{
//
} catch (IOException e) {
throw
Message
.
convertIOException
(
e
,
null
);
//
throw Message.convertIOException(e, null);
}
//
}
}
//
}
}
}
h2/src/main/org/h2/store/PageOutputStream.java
浏览文件 @
47c6a50f
...
@@ -11,12 +11,14 @@ import java.io.OutputStream;
...
@@ -11,12 +11,14 @@ import java.io.OutputStream;
import
java.sql.SQLException
;
import
java.sql.SQLException
;
import
org.h2.index.Page
;
import
org.h2.index.Page
;
import
org.h2.message.Message
;
import
org.h2.message.Message
;
import
org.h2.message.Trace
;
/**
/**
* An output stream that writes into a page store.
* An output stream that writes into a page store.
*/
*/
public
class
PageOutputStream
extends
OutputStream
{
public
class
PageOutputStream
extends
OutputStream
{
private
final
Trace
trace
;
private
PageStore
store
;
private
PageStore
store
;
private
int
parentPage
;
private
int
parentPage
;
private
int
type
;
private
int
type
;
...
@@ -34,6 +36,7 @@ public class PageOutputStream extends OutputStream {
...
@@ -34,6 +36,7 @@ public class PageOutputStream extends OutputStream {
* @param type the page type
* @param type the page type
*/
*/
public
PageOutputStream
(
PageStore
store
,
int
parentPage
,
int
headPage
,
int
type
)
{
public
PageOutputStream
(
PageStore
store
,
int
parentPage
,
int
headPage
,
int
type
)
{
this
.
trace
=
store
.
getTrace
();
this
.
store
=
store
;
this
.
store
=
store
;
this
.
parentPage
=
parentPage
;
this
.
parentPage
=
parentPage
;
this
.
nextPage
=
headPage
;
this
.
nextPage
=
headPage
;
...
@@ -43,6 +46,7 @@ public class PageOutputStream extends OutputStream {
...
@@ -43,6 +46,7 @@ public class PageOutputStream extends OutputStream {
}
}
public
void
write
(
int
b
)
throws
IOException
{
public
void
write
(
int
b
)
throws
IOException
{
int
todoOptimizeIfNeeded
;
write
(
new
byte
[]
{
(
byte
)
b
});
write
(
new
byte
[]
{
(
byte
)
b
});
}
}
...
@@ -62,7 +66,7 @@ public class PageOutputStream extends OutputStream {
...
@@ -62,7 +66,7 @@ public class PageOutputStream extends OutputStream {
if
(
len
<=
0
)
{
if
(
len
<=
0
)
{
return
;
return
;
}
}
while
(
len
>
remaining
)
{
while
(
len
>
=
remaining
)
{
page
.
write
(
b
,
off
,
remaining
);
page
.
write
(
b
,
off
,
remaining
);
off
+=
remaining
;
off
+=
remaining
;
len
-=
remaining
;
len
-=
remaining
;
...
@@ -83,8 +87,9 @@ public class PageOutputStream extends OutputStream {
...
@@ -83,8 +87,9 @@ public class PageOutputStream extends OutputStream {
private
void
storePage
()
throws
IOException
{
private
void
storePage
()
throws
IOException
{
try
{
try
{
int
test
;
if
(
trace
.
isDebugEnabled
())
{
System
.
out
.
println
(
" pageOut.storePage "
+
pageId
+
" next:"
+
nextPage
);
trace
.
debug
(
"pageOut.storePage "
+
pageId
+
" next:"
+
nextPage
);
}
store
.
writePage
(
pageId
,
page
);
store
.
writePage
(
pageId
,
page
);
}
catch
(
SQLException
e
)
{
}
catch
(
SQLException
e
)
{
throw
Message
.
convertToIOException
(
e
);
throw
Message
.
convertToIOException
(
e
);
...
@@ -113,33 +118,4 @@ System.out.println(" pageOut.storePage " + pageId + " next:" + nextPage);
...
@@ -113,33 +118,4 @@ System.out.println(" pageOut.storePage " + pageId + " next:" + nextPage);
return
remaining
;
return
remaining
;
}
}
// public void write(byte[] buff, int off, int len) throws IOException {
// if (len > 0) {
// try {
// page.reset();
// if (compress != null) {
// if (off != 0 || len != buff.length) {
// byte[] b2 = new byte[len];
// System.arraycopy(buff, off, b2, 0, len);
// buff = b2;
// off = 0;
// }
// int uncompressed = len;
// buff = compress.compress(buff, compressionAlgorithm);
// len = buff.length;
// page.writeInt(len);
// page.writeInt(uncompressed);
// page.write(buff, off, len);
// } else {
// page.writeInt(len);
// page.write(buff, off, len);
// }
// page.fillAligned();
// store.write(page.getBytes(), 0, page.length());
// } catch (SQLException e) {
// throw Message.convertToIOException(e);
// }
// }
// }
}
}
h2/src/main/org/h2/store/PageStore.java
浏览文件 @
47c6a50f
...
@@ -7,11 +7,14 @@
...
@@ -7,11 +7,14 @@
package
org
.
h2
.
store
;
package
org
.
h2
.
store
;
import
java.io.IOException
;
import
java.io.IOException
;
import
java.io.OutputStream
;
import
java.sql.SQLException
;
import
java.sql.SQLException
;
import
org.h2.constant.ErrorCode
;
import
org.h2.constant.ErrorCode
;
import
org.h2.engine.Database
;
import
org.h2.engine.Database
;
import
org.h2.index.Page
;
import
org.h2.message.Message
;
import
org.h2.message.Message
;
import
org.h2.message.Trace
;
import
org.h2.message.Trace
;
import
org.h2.message.TraceSystem
;
import
org.h2.util.Cache
;
import
org.h2.util.Cache
;
import
org.h2.util.Cache2Q
;
import
org.h2.util.Cache2Q
;
import
org.h2.util.CacheLRU
;
import
org.h2.util.CacheLRU
;
...
@@ -45,6 +48,7 @@ public class PageStore implements CacheWriter {
...
@@ -45,6 +48,7 @@ public class PageStore implements CacheWriter {
private
static
final
int
WRITE_VERSION
=
0
;
private
static
final
int
WRITE_VERSION
=
0
;
private
Database
database
;
private
Database
database
;
private
final
Trace
trace
;
private
String
fileName
;
private
String
fileName
;
private
FileStore
file
;
private
FileStore
file
;
private
String
accessMode
;
private
String
accessMode
;
...
@@ -99,6 +103,9 @@ public class PageStore implements CacheWriter {
...
@@ -99,6 +103,9 @@ public class PageStore implements CacheWriter {
*/
*/
public
PageStore
(
Database
database
,
String
fileName
,
String
accessMode
,
int
cacheSizeDefault
)
{
public
PageStore
(
Database
database
,
String
fileName
,
String
accessMode
,
int
cacheSizeDefault
)
{
this
.
database
=
database
;
this
.
database
=
database
;
trace
=
database
.
getTrace
(
Trace
.
PAGE_STORE
);
int
test
;
trace
.
setLevel
(
TraceSystem
.
DEBUG
);
this
.
fileName
=
fileName
;
this
.
fileName
=
fileName
;
this
.
accessMode
=
accessMode
;
this
.
accessMode
=
accessMode
;
this
.
cacheSize
=
cacheSizeDefault
;
this
.
cacheSize
=
cacheSizeDefault
;
...
@@ -110,6 +117,30 @@ public class PageStore implements CacheWriter {
...
@@ -110,6 +117,30 @@ public class PageStore implements CacheWriter {
}
}
}
}
/**
* Copy the next page to the output stream.
*
* @param pageId the page to copy
* @param out the output stream
* @return the new position, or -1 if there is no more data to copy
*/
public
int
copyDirect
(
int
pageId
,
OutputStream
out
)
throws
SQLException
{
synchronized
(
database
)
{
byte
[]
buffer
=
new
byte
[
pageSize
];
try
{
if
(
pageId
>=
pageCount
)
{
return
-
1
;
}
file
.
seek
(
pageId
*
pageSize
);
file
.
readFullyDirect
(
buffer
,
0
,
pageSize
);
out
.
write
(
buffer
,
0
,
pageSize
);
return
pageId
+
1
;
}
catch
(
IOException
e
)
{
throw
Message
.
convertIOException
(
e
,
fileName
);
}
}
}
/**
/**
* Open the file and read the header.
* Open the file and read the header.
*/
*/
...
@@ -121,6 +152,16 @@ public class PageStore implements CacheWriter {
...
@@ -121,6 +152,16 @@ public class PageStore implements CacheWriter {
fileLength
=
file
.
length
();
fileLength
=
file
.
length
();
pageCount
=
(
int
)
(
fileLength
/
pageSize
);
pageCount
=
(
int
)
(
fileLength
/
pageSize
);
log
=
new
PageLog
(
this
,
logRootPageId
);
log
=
new
PageLog
(
this
,
logRootPageId
);
lastUsedPage
=
pageCount
-
1
;
while
(
true
)
{
DataPage
page
=
readPage
(
lastUsedPage
);
page
.
readInt
();
int
type
=
page
.
readByte
();
if
(
type
!=
Page
.
TYPE_EMPTY
)
{
break
;
}
lastUsedPage
--;
}
}
else
{
}
else
{
isNew
=
true
;
isNew
=
true
;
setPageSize
(
PAGE_SIZE_DEFAULT
);
setPageSize
(
PAGE_SIZE_DEFAULT
);
...
@@ -147,7 +188,7 @@ public class PageStore implements CacheWriter {
...
@@ -147,7 +188,7 @@ public class PageStore implements CacheWriter {
* Flush all pending changes to disk, and re-open the log file.
* Flush all pending changes to disk, and re-open the log file.
*/
*/
public
void
checkpoint
()
throws
SQLException
{
public
void
checkpoint
()
throws
SQLException
{
System
.
out
.
println
(
"PageStore.
checkpoint"
);
trace
.
debug
(
"
checkpoint"
);
synchronized
(
database
)
{
synchronized
(
database
)
{
database
.
checkPowerOff
();
database
.
checkPowerOff
();
ObjectArray
list
=
cache
.
getAllChanged
();
ObjectArray
list
=
cache
.
getAllChanged
();
...
@@ -156,9 +197,12 @@ System.out.println("PageStore.checkpoint");
...
@@ -156,9 +197,12 @@ System.out.println("PageStore.checkpoint");
Record
rec
=
(
Record
)
list
.
get
(
i
);
Record
rec
=
(
Record
)
list
.
get
(
i
);
writeBack
(
rec
);
writeBack
(
rec
);
}
}
int
todoFlushBeforeReopen
;
log
.
reopen
();
log
.
reopen
();
int
todoWriteDeletedPages
;
int
todoWriteDeletedPages
;
}
}
pageCount
=
lastUsedPage
+
1
;
file
.
setLength
(
pageSize
*
pageCount
);
}
}
private
void
readHeader
()
throws
SQLException
{
private
void
readHeader
()
throws
SQLException
{
...
@@ -240,15 +284,15 @@ System.out.println("PageStore.checkpoint");
...
@@ -240,15 +284,15 @@ System.out.println("PageStore.checkpoint");
}
}
/**
/**
* Close the file without
flushing the cache
.
* Close the file without
writing anything
.
*/
*/
public
void
close
()
throws
SQLException
{
public
void
close
()
throws
SQLException
{
int
todoTruncateLog
;
try
{
try
{
trace
.
debug
(
"close"
);
if
(
file
!=
null
)
{
if
(
file
!=
null
)
{
log
.
close
();
file
.
close
();
file
.
close
();
}
}
file
=
null
;
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
Message
.
convertIOException
(
e
,
"close"
);
throw
Message
.
convertIOException
(
e
,
"close"
);
}
}
...
@@ -259,14 +303,15 @@ System.out.println("PageStore.checkpoint");
...
@@ -259,14 +303,15 @@ System.out.println("PageStore.checkpoint");
}
}
public
Trace
getTrace
()
{
public
Trace
getTrace
()
{
return
database
.
getTrace
(
Trace
.
DATABASE
)
;
return
trace
;
}
}
public
void
writeBack
(
CacheObject
obj
)
throws
SQLException
{
public
void
writeBack
(
CacheObject
obj
)
throws
SQLException
{
synchronized
(
database
)
{
synchronized
(
database
)
{
Record
record
=
(
Record
)
obj
;
Record
record
=
(
Record
)
obj
;
int
test
;
if
(
trace
.
isDebugEnabled
())
{
System
.
out
.
println
(
"writeBack "
+
record
.
getPos
()
+
":"
+
record
);
trace
.
debug
(
"writeBack "
+
record
.
getPos
()
+
":"
+
record
);
}
int
todoRemoveParameter
;
int
todoRemoveParameter
;
record
.
write
(
null
);
record
.
write
(
null
);
record
.
setChanged
(
false
);
record
.
setChanged
(
false
);
...
@@ -281,6 +326,9 @@ System.out.println("writeBack " + record.getPos() + ":" + record);
...
@@ -281,6 +326,9 @@ System.out.println("writeBack " + record.getPos() + ":" + record);
*/
*/
public
void
updateRecord
(
Record
record
,
DataPage
old
)
throws
SQLException
{
public
void
updateRecord
(
Record
record
,
DataPage
old
)
throws
SQLException
{
int
todoLogHeaderPageAsWell
;
int
todoLogHeaderPageAsWell
;
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"updateRecord "
+
record
.
getPos
()
+
" "
+
record
.
toString
());
}
synchronized
(
database
)
{
synchronized
(
database
)
{
record
.
setChanged
(
true
);
record
.
setChanged
(
true
);
int
pos
=
record
.
getPos
();
int
pos
=
record
.
getPos
();
...
@@ -331,6 +379,9 @@ System.out.println("writeBack " + record.getPos() + ":" + record);
...
@@ -331,6 +379,9 @@ System.out.println("writeBack " + record.getPos() + ":" + record);
* @param pageId the page id
* @param pageId the page id
*/
*/
public
void
freePage
(
int
pageId
)
throws
SQLException
{
public
void
freePage
(
int
pageId
)
throws
SQLException
{
if
(
trace
.
isDebugEnabled
())
{
trace
.
debug
(
"freePage "
+
pageId
);
}
freePageCount
++;
freePageCount
++;
PageFreeList
free
;
PageFreeList
free
;
cache
.
remove
(
pageId
);
cache
.
remove
(
pageId
);
...
...
h2/src/main/org/h2/tools/Restore.java
浏览文件 @
47c6a50f
...
@@ -173,7 +173,7 @@ public class Restore extends Tool {
...
@@ -173,7 +173,7 @@ public class Restore extends Tool {
boolean
copy
=
false
;
boolean
copy
=
false
;
if
(
db
==
null
)
{
if
(
db
==
null
)
{
copy
=
true
;
copy
=
true
;
}
else
if
(
fileName
.
startsWith
(
originalDbName
))
{
}
else
if
(
fileName
.
startsWith
(
originalDbName
+
"."
))
{
fileName
=
db
+
fileName
.
substring
(
originalDbName
.
length
());
fileName
=
db
+
fileName
.
substring
(
originalDbName
.
length
());
copy
=
true
;
copy
=
true
;
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论