Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
90683da1
D
dbeaver
项目概览
suliangchun
/
dbeaver
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dbeaver
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
90683da1
编写于
2月 16, 2018
作者:
S
serge-rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#24 Partner license
上级
582ae0ac
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
23 addition
and
18 deletion
+23
-18
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/syntax/SQLCompletionAnalyzer.java
.../dbeaver/ui/editors/sql/syntax/SQLCompletionAnalyzer.java
+20
-18
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/syntax/SQLCompletionProcessor.java
...dbeaver/ui/editors/sql/syntax/SQLCompletionProcessor.java
+3
-0
未找到文件。
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/syntax/SQLCompletionAnalyzer.java
浏览文件 @
90683da1
...
...
@@ -20,7 +20,6 @@ import org.eclipse.swt.graphics.Image;
import
org.jkiss.code.Nullable
;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.Log
;
import
org.jkiss.dbeaver.core.DBeaverCore
;
import
org.jkiss.dbeaver.model.*
;
import
org.jkiss.dbeaver.model.impl.DBObjectNameCaseTransformer
;
import
org.jkiss.dbeaver.model.navigator.DBNNode
;
...
...
@@ -105,6 +104,13 @@ class SQLCompletionAnalyzer
if
(
rootObject
!=
null
)
{
makeProposalsFromChildren
(
rootObject
,
null
);
}
if
(
request
.
queryType
==
SQLCompletionProcessor
.
QueryType
.
JOIN
&&
!
request
.
proposals
.
isEmpty
()
&&
dataSource
instanceof
DBSObjectContainer
)
{
// Filter out non-joinable tables
DBSObject
leftTable
=
getTableFromAlias
((
DBSObjectContainer
)
dataSource
,
null
);
if
(
leftTable
!=
null
)
{
filterNonJoinableProposals
(
leftTable
);
}
}
}
else
{
DBSObject
rootObject
=
null
;
if
(
request
.
queryType
==
SQLCompletionProcessor
.
QueryType
.
COLUMN
&&
dataSource
instanceof
DBSObjectContainer
)
{
...
...
@@ -132,6 +138,10 @@ class SQLCompletionAnalyzer
}
}
private
void
filterNonJoinableProposals
(
DBSObject
leftTable
)
{
// Remove all table proposals which don't have FKs between them and leftTable
}
private
void
makeDataSourceProposals
()
{
DBPDataSource
dataSource
=
request
.
editor
.
getDataSource
();
...
...
@@ -473,26 +483,18 @@ class SQLCompletionAnalyzer
}
else
if
(!
matchedObjects
.
isEmpty
())
{
if
(
startPart
!=
null
)
{
if
(
simpleMode
)
{
Collections
.
sort
(
matchedObjects
,
new
Comparator
<
DBSObject
>()
{
@Override
public
int
compare
(
DBSObject
o1
,
DBSObject
o2
)
{
return
o1
.
getName
().
compareTo
(
o2
.
getName
());
}
});
matchedObjects
.
sort
(
Comparator
.
comparing
(
DBPNamedObject:
:
getName
));
}
else
{
Collections
.
sort
(
matchedObjects
,
new
Comparator
<
DBSObject
>()
{
@Override
public
int
compare
(
DBSObject
o1
,
DBSObject
o2
)
{
int
score1
=
scoredMatches
.
get
(
o1
.
getName
());
int
score2
=
scoredMatches
.
get
(
o2
.
getName
());
if
(
score1
==
score2
)
{
if
(
o1
instanceof
DBSAttributeBase
)
{
return
((
DBSAttributeBase
)
o1
).
getOrdinalPosition
()
-
((
DBSAttributeBase
)
o2
).
getOrdinalPosition
();
}
return
o1
.
getName
().
compareTo
(
o2
.
getName
());
matchedObjects
.
sort
((
o1
,
o2
)
->
{
int
score1
=
scoredMatches
.
get
(
o1
.
getName
());
int
score2
=
scoredMatches
.
get
(
o2
.
getName
());
if
(
score1
==
score2
)
{
if
(
o1
instanceof
DBSAttributeBase
)
{
return
((
DBSAttributeBase
)
o1
).
getOrdinalPosition
()
-
((
DBSAttributeBase
)
o2
).
getOrdinalPosition
();
}
return
score2
-
score1
;
return
o1
.
getName
().
compareTo
(
o2
.
getName
())
;
}
return
score2
-
score1
;
});
}
}
...
...
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/syntax/SQLCompletionProcessor.java
浏览文件 @
90683da1
...
...
@@ -58,6 +58,7 @@ public class SQLCompletionProcessor implements IContentAssistProcessor
enum
QueryType
{
TABLE
,
JOIN
,
COLUMN
}
...
...
@@ -121,6 +122,8 @@ public class SQLCompletionProcessor implements IContentAssistProcessor
(
"("
.
equals
(
wordDetector
.
getPrevDelimiter
())
||
","
.
equals
(
wordDetector
.
getPrevDelimiter
())))
{
request
.
queryType
=
QueryType
.
COLUMN
;
}
else
if
(
SQLConstants
.
KEYWORD_JOIN
.
equals
(
prevKeyWord
))
{
request
.
queryType
=
QueryType
.
JOIN
;
}
else
{
request
.
queryType
=
QueryType
.
TABLE
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录