Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
fbff440a
提交
fbff440a
authored
14 年前
作者:
Thomas Mueller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Switch to beta.
上级
a2f179e4
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
无相关合并请求
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
34 行增加
和
34 行删除
+34
-34
FullTextLucene.java
h2/src/main/org/h2/fulltext/FullTextLucene.java
+34
-34
没有找到文件。
h2/src/main/org/h2/fulltext/FullTextLucene.java
浏览文件 @
fbff440a
...
@@ -39,11 +39,11 @@ import org.h2.util.New;
...
@@ -39,11 +39,11 @@ import org.h2.util.New;
import
org.h2.util.StatementBuilder
;
import
org.h2.util.StatementBuilder
;
import
org.h2.util.StringUtils
;
import
org.h2.util.StringUtils
;
//## Java 1.4 end ##
//## Java 1.4 end ##
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
import org.apache.lucene.index.IndexModifier;
import org.apache.lucene.index.IndexModifier;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.Hits;
//## LUCENE2 end ##
## LUCENE2 end ##*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
import
java.io.File
;
import
java.io.File
;
import
org.apache.lucene.search.ScoreDoc
;
import
org.apache.lucene.search.ScoreDoc
;
import
org.apache.lucene.search.TopDocs
;
import
org.apache.lucene.search.TopDocs
;
...
@@ -51,7 +51,7 @@ import org.apache.lucene.store.FSDirectory;
...
@@ -51,7 +51,7 @@ import org.apache.lucene.store.FSDirectory;
import
org.apache.lucene.store.Directory
;
import
org.apache.lucene.store.Directory
;
import
org.apache.lucene.util.Version
;
import
org.apache.lucene.util.Version
;
import
org.apache.lucene.index.IndexWriter
;
import
org.apache.lucene.index.IndexWriter
;
## LUCENE3 end ##*/
//## LUCENE3 end ##
/**
/**
* This class implements the full text search based on Apache Lucene.
* This class implements the full text search based on Apache Lucene.
...
@@ -268,13 +268,13 @@ public class FullTextLucene extends FullText {
...
@@ -268,13 +268,13 @@ public class FullTextLucene extends FullText {
IndexAccess
access
=
INDEX_ACCESS
.
get
(
path
);
IndexAccess
access
=
INDEX_ACCESS
.
get
(
path
);
if
(
access
==
null
)
{
if
(
access
==
null
)
{
try
{
try
{
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
boolean recreate = !IndexReader.indexExists(path);
boolean recreate = !IndexReader.indexExists(path);
Analyzer analyzer = new StandardAnalyzer();
Analyzer analyzer = new StandardAnalyzer();
access = new IndexAccess();
access = new IndexAccess();
access.modifier = new IndexModifier(path, analyzer, recreate);
access.modifier = new IndexModifier(path, analyzer, recreate);
//## LUCENE2 end ##
## LUCENE2 end ##*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
File
f
=
new
File
(
path
);
File
f
=
new
File
(
path
);
Directory
indexDir
=
FSDirectory
.
open
(
f
);
Directory
indexDir
=
FSDirectory
.
open
(
f
);
boolean
recreate
=
!
IndexReader
.
indexExists
(
indexDir
);
boolean
recreate
=
!
IndexReader
.
indexExists
(
indexDir
);
...
@@ -287,7 +287,7 @@ public class FullTextLucene extends FullText {
...
@@ -287,7 +287,7 @@ public class FullTextLucene extends FullText {
access
.
writer
=
writer
;
access
.
writer
=
writer
;
access
.
reader
=
reader
;
access
.
reader
=
reader
;
access
.
searcher
=
new
IndexSearcher
(
reader
);
access
.
searcher
=
new
IndexSearcher
(
reader
);
## LUCENE3 end ##*/
//## LUCENE3 end ##
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
convertException
(
e
);
throw
convertException
(
e
);
}
}
...
@@ -361,15 +361,15 @@ public class FullTextLucene extends FullText {
...
@@ -361,15 +361,15 @@ public class FullTextLucene extends FullText {
synchronized
(
INDEX_ACCESS
)
{
synchronized
(
INDEX_ACCESS
)
{
try
{
try
{
INDEX_ACCESS
.
remove
(
indexPath
);
INDEX_ACCESS
.
remove
(
indexPath
);
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
access.modifier.flush();
access.modifier.flush();
access.modifier.close();
access.modifier.close();
//## LUCENE2 end ##
## LUCENE2 end ##*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
access
.
searcher
.
close
();
access
.
searcher
.
close
();
access
.
reader
.
close
();
access
.
reader
.
close
();
access
.
writer
.
close
();
access
.
writer
.
close
();
## LUCENE3 end ##*/
//## LUCENE3 end ##
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
throw
convertException
(
e
);
throw
convertException
(
e
);
}
}
...
@@ -397,7 +397,7 @@ public class FullTextLucene extends FullText {
...
@@ -397,7 +397,7 @@ public class FullTextLucene extends FullText {
}
}
try
{
try
{
IndexAccess
access
=
getIndexAccess
(
conn
);
IndexAccess
access
=
getIndexAccess
(
conn
);
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
access.modifier.flush();
access.modifier.flush();
String path = getIndexPath(conn);
String path = getIndexPath(conn);
IndexReader reader = IndexReader.open(path);
IndexReader reader = IndexReader.open(path);
...
@@ -413,8 +413,8 @@ public class FullTextLucene extends FullText {
...
@@ -413,8 +413,8 @@ public class FullTextLucene extends FullText {
for (int i = 0; i < limit && i + offset < max; i++) {
for (int i = 0; i < limit && i + offset < max; i++) {
Document doc = hits.doc(i + offset);
Document doc = hits.doc(i + offset);
float score = hits.score(i + offset);
float score = hits.score(i + offset);
//## LUCENE2 end ##
## LUCENE2 end ##*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
// take a reference as the searcher may change
// take a reference as the searcher may change
Searcher
searcher
=
access
.
searcher
;
Searcher
searcher
=
access
.
searcher
;
// reuse the same analyzer; it's thread-safe;
// reuse the same analyzer; it's thread-safe;
...
@@ -438,7 +438,7 @@ public class FullTextLucene extends FullText {
...
@@ -438,7 +438,7 @@ public class FullTextLucene extends FullText {
ScoreDoc
sd
=
docs
.
scoreDocs
[
i
+
offset
];
ScoreDoc
sd
=
docs
.
scoreDocs
[
i
+
offset
];
Document
doc
=
searcher
.
doc
(
sd
.
doc
);
Document
doc
=
searcher
.
doc
(
sd
.
doc
);
float
score
=
sd
.
score
;
float
score
=
sd
.
score
;
## LUCENE3 end ##*/
//## LUCENE3 end ##
String
q
=
doc
.
get
(
LUCENE_FIELD_QUERY
);
String
q
=
doc
.
get
(
LUCENE_FIELD_QUERY
);
if
(
data
)
{
if
(
data
)
{
int
idx
=
q
.
indexOf
(
" WHERE "
);
int
idx
=
q
.
indexOf
(
" WHERE "
);
...
@@ -461,10 +461,10 @@ public class FullTextLucene extends FullText {
...
@@ -461,10 +461,10 @@ public class FullTextLucene extends FullText {
result
.
addRow
(
q
,
score
);
result
.
addRow
(
q
,
score
);
}
}
}
}
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
// TODO keep it open if possible
// TODO keep it open if possible
reader.close();
reader.close();
//## LUCENE2 end ##
## LUCENE2 end ##*/
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
throw
convertException
(
e
);
throw
convertException
(
e
);
}
}
...
@@ -607,7 +607,7 @@ public class FullTextLucene extends FullText {
...
@@ -607,7 +607,7 @@ public class FullTextLucene extends FullText {
* @param row the row
* @param row the row
*/
*/
protected
void
insert
(
Object
[]
row
)
throws
SQLException
{
protected
void
insert
(
Object
[]
row
)
throws
SQLException
{
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
String query = getQuery(row);
String query = getQuery(row);
Document doc = new Document();
Document doc = new Document();
doc.add(new Field(LUCENE_FIELD_QUERY, query,
doc.add(new Field(LUCENE_FIELD_QUERY, query,
...
@@ -639,8 +639,8 @@ public class FullTextLucene extends FullText {
...
@@ -639,8 +639,8 @@ public class FullTextLucene extends FullText {
} catch (IOException e) {
} catch (IOException e) {
throw convertException(e);
throw convertException(e);
}
}
//## LUCENE2 end ##
## LUCENE2 end ##*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
String
query
=
getQuery
(
row
);
String
query
=
getQuery
(
row
);
Document
doc
=
new
Document
();
Document
doc
=
new
Document
();
doc
.
add
(
new
Field
(
LUCENE_FIELD_QUERY
,
query
,
doc
.
add
(
new
Field
(
LUCENE_FIELD_QUERY
,
query
,
...
@@ -680,7 +680,7 @@ public class FullTextLucene extends FullText {
...
@@ -680,7 +680,7 @@ public class FullTextLucene extends FullText {
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
convertException
(
e
);
throw
convertException
(
e
);
}
}
## LUCENE3 end ##*/
//## LUCENE3 end ##
}
}
/**
/**
...
@@ -692,12 +692,12 @@ public class FullTextLucene extends FullText {
...
@@ -692,12 +692,12 @@ public class FullTextLucene extends FullText {
String
query
=
getQuery
(
row
);
String
query
=
getQuery
(
row
);
try
{
try
{
Term
term
=
new
Term
(
LUCENE_FIELD_QUERY
,
query
);
Term
term
=
new
Term
(
LUCENE_FIELD_QUERY
,
query
);
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
indexAccess.modifier.deleteDocuments(term);
indexAccess.modifier.deleteDocuments(term);
//## LUCENE2 end ##
## LUCENE2 end ##*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
indexAccess
.
writer
.
deleteDocuments
(
term
);
indexAccess
.
writer
.
deleteDocuments
(
term
);
## LUCENE3 end ##*/
//## LUCENE3 end ##
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
convertException
(
e
);
throw
convertException
(
e
);
}
}
...
@@ -731,30 +731,30 @@ public class FullTextLucene extends FullText {
...
@@ -731,30 +731,30 @@ public class FullTextLucene extends FullText {
/**
/**
* The index modified.
* The index modified.
*/
*/
/
/
## LUCENE2 begin ##
/
*
## LUCENE2 begin ##
IndexModifier modifier;
IndexModifier modifier;
//## LUCENE2 end ##
## LUCENE2 end ##*/
/**
/**
* The index writer.
* The index writer.
*/
*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
IndexWriter
writer
;
IndexWriter
writer
;
## LUCENE3 end ##*/
//## LUCENE3 end ##
/**
/**
* The index reader.
* The index reader.
*/
*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
IndexReader
reader
;
IndexReader
reader
;
## LUCENE3 end ##*/
//## LUCENE3 end ##
/**
/**
* The index searcher.
* The index searcher.
*/
*/
/
*
## LUCENE3 begin ##
/
/
## LUCENE3 begin ##
Searcher
searcher
;
Searcher
searcher
;
## LUCENE3 end ##*/
//## LUCENE3 end ##
}
}
}
}
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论