Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
35b2460d
D
dbeaver
项目概览
suliangchun
/
dbeaver
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
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,发现更多精彩内容 >>
提交
35b2460d
编写于
5月 07, 2017
作者:
S
Serge Rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#1635 Parse SQL parameters for non-DDL queries
上级
70451c75
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
49 addition
and
7 deletion
+49
-7
modules/org.jkiss.utils/src/org/jkiss/utils/ArrayUtils.java
modules/org.jkiss.utils/src/org/jkiss/utils/ArrayUtils.java
+11
-0
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/SQLEditorBase.java
...e/src/org/jkiss/dbeaver/ui/editors/sql/SQLEditorBase.java
+22
-7
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/sql/BasicSQLDialect.java
...src/org/jkiss/dbeaver/model/impl/sql/BasicSQLDialect.java
+9
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/sql/SQLDialect.java
...ver.model/src/org/jkiss/dbeaver/model/sql/SQLDialect.java
+7
-0
未找到文件。
modules/org.jkiss.utils/src/org/jkiss/utils/ArrayUtils.java
浏览文件 @
35b2460d
...
...
@@ -104,6 +104,17 @@ public class ArrayUtils {
return
false
;
}
public
static
boolean
containsIgnoreCase
(
String
[]
array
,
String
value
)
{
if
(
isEmpty
(
array
)
||
value
==
null
)
return
false
;
for
(
int
i
=
0
;
i
<
array
.
length
;
i
++)
{
if
(
value
.
equalsIgnoreCase
(
array
[
i
]))
return
true
;
}
return
false
;
}
public
static
<
OBJECT_TYPE
>
boolean
containsRef
(
@NotNull
OBJECT_TYPE
[]
array
,
@Nullable
OBJECT_TYPE
value
)
{
final
int
length
=
array
.
length
;
...
...
plugins/org.jkiss.dbeaver.core/src/org/jkiss/dbeaver/ui/editors/sql/SQLEditorBase.java
浏览文件 @
35b2460d
...
...
@@ -61,6 +61,7 @@ import org.jkiss.dbeaver.ui.editors.sql.templates.SQLTemplatesPage;
import
org.jkiss.dbeaver.ui.editors.sql.util.SQLSymbolInserter
;
import
org.jkiss.dbeaver.ui.editors.text.BaseTextEditor
;
import
org.jkiss.dbeaver.ui.preferences.*
;
import
org.jkiss.utils.ArrayUtils
;
import
org.jkiss.utils.CommonUtils
;
import
org.jkiss.utils.Pair
;
...
...
@@ -826,10 +827,12 @@ public abstract class SQLEditorBase extends BaseTextEditor implements IErrorVisu
}
protected
List
<
SQLQueryParameter
>
parseParameters
(
IDocument
document
,
SQLQuery
query
)
{
boolean
execQuery
=
SQLUtils
.
isExecQuery
(
getSQLDialect
(),
query
.
getText
());
final
SQLDialect
sqlDialect
=
getSQLDialect
();
boolean
execQuery
=
false
;
List
<
SQLQueryParameter
>
parameters
=
null
;
ruleManager
.
setRange
(
document
,
query
.
getOffset
(),
query
.
getLength
());
int
blockDepth
=
0
;
boolean
firstKeyword
=
true
;
for
(;;)
{
IToken
token
=
ruleManager
.
nextToken
();
int
tokenOffset
=
ruleManager
.
getTokenOffset
();
...
...
@@ -842,12 +845,24 @@ public abstract class SQLEditorBase extends BaseTextEditor implements IErrorVisu
if
(
token
instanceof
SQLToken
)
{
tokenType
=
((
SQLToken
)
token
).
getType
();
}
if
(
tokenType
==
SQLToken
.
T_BLOCK_BEGIN
)
{
blockDepth
++;
}
else
if
(
tokenType
==
SQLToken
.
T_BLOCK_END
)
{
blockDepth
--;
if
(
token
.
isWhitespace
()
||
tokenType
==
SQLToken
.
T_COMMENT
)
{
continue
;
}
if
(
firstKeyword
)
{
// Detect query type
try
{
String
tokenText
=
document
.
get
(
tokenOffset
,
tokenLength
);
if
(
ArrayUtils
.
containsIgnoreCase
(
sqlDialect
.
getDDLKeywords
(),
tokenText
))
{
// DDL doesn't support parameters
return
null
;
}
execQuery
=
ArrayUtils
.
containsIgnoreCase
(
sqlDialect
.
getExecuteKeywords
(),
tokenText
);
}
catch
(
BadLocationException
e
)
{
log
.
warn
(
e
);
}
firstKeyword
=
false
;
}
if
(
tokenType
==
SQLToken
.
T_PARAMETER
&&
tokenLength
>
0
&&
blockDepth
<=
0
)
{
if
(
tokenType
==
SQLToken
.
T_PARAMETER
&&
tokenLength
>
0
)
{
try
{
String
paramName
=
document
.
get
(
tokenOffset
,
tokenLength
);
if
(
execQuery
&&
paramName
.
equals
(
"?"
))
{
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/sql/BasicSQLDialect.java
浏览文件 @
35b2460d
...
...
@@ -42,6 +42,9 @@ public class BasicSQLDialect implements SQLDialect {
private
static
final
String
[]
DEFAULT_LINE_COMMENTS
=
{
SQLConstants
.
SL_COMMENT
};
private
static
final
String
[]
EXEC_KEYWORDS
=
new
String
[
0
];
private
static
final
String
[]
DDL_KEYWORDS
=
new
String
[]
{
"CREATE"
,
"ALTER"
,
"DROP"
};
private
static
final
String
[][]
DEFAULT_BEGIN_END_BLOCK
=
new
String
[][]{
{
SQLConstants
.
BLOCK_BEGIN
,
SQLConstants
.
BLOCK_END
}
...
...
@@ -90,6 +93,12 @@ public class BasicSQLDialect implements SQLDialect {
return
EXEC_KEYWORDS
;
}
@NotNull
@Override
public
String
[]
getDDLKeywords
()
{
return
DDL_KEYWORDS
;
}
protected
void
addSQLKeyword
(
String
keyword
)
{
reservedWords
.
add
(
keyword
);
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/sql/SQLDialect.java
浏览文件 @
35b2460d
...
...
@@ -71,6 +71,13 @@ public interface SQLDialect {
@NotNull
String
[]
getExecuteKeywords
();
/**
* Retrieves a list of execute keywords. If database doesn't support implicit execute returns empty list or null.
* @return the list of execute keywords.
*/
@NotNull
String
[]
getDDLKeywords
();
/**
* Retrieves a list of all of this database's SQL keywords
* that are NOT also SQL92 keywords.
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录