Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
65a49e34
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,发现更多精彩内容 >>
提交
65a49e34
编写于
1月 05, 2018
作者:
S
serge-rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#2656 Statement execute fix - limit apply check (workaround for SQL Server)
上级
18823797
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
17 addition
and
3 deletion
+17
-3
plugins/org.jkiss.dbeaver.ext.mssql/src/org/jkiss/dbeaver/ext/mssql/model/SQLServerDataSource.java
...rg/jkiss/dbeaver/ext/mssql/model/SQLServerDataSource.java
+9
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/DBConstants.java
...beaver.model/src/org/jkiss/dbeaver/model/DBConstants.java
+2
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/DBUtils.java
...ss.dbeaver.model/src/org/jkiss/dbeaver/model/DBUtils.java
+6
-3
未找到文件。
plugins/org.jkiss.dbeaver.ext.mssql/src/org/jkiss/dbeaver/ext/mssql/model/SQLServerDataSource.java
浏览文件 @
65a49e34
...
...
@@ -19,6 +19,7 @@ package org.jkiss.dbeaver.ext.mssql.model;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.ext.generic.model.GenericDataSource
;
import
org.jkiss.dbeaver.ext.mssql.SQLServerConstants
;
import
org.jkiss.dbeaver.model.DBConstants
;
import
org.jkiss.dbeaver.model.DBPDataSourceContainer
;
import
org.jkiss.dbeaver.model.connection.DBPConnectionConfiguration
;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
...
...
@@ -41,6 +42,14 @@ public class SQLServerDataSource extends GenericDataSource {
super
(
monitor
,
container
,
metaModel
,
new
SQLServerDialect
());
}
@Override
public
Object
getDataSourceFeature
(
String
featureId
)
{
if
(
DBConstants
.
FEATURE_LIMIT_AFFECTS_DML
.
equals
(
featureId
))
{
return
true
;
}
return
super
.
getDataSourceFeature
(
featureId
);
}
//////////////////////////////////////////////////////////
// Databases
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/DBConstants.java
浏览文件 @
65a49e34
...
...
@@ -28,6 +28,8 @@ import java.util.Locale;
*/
public
class
DBConstants
{
public
static
final
String
FEATURE_LIMIT_AFFECTS_DML
=
"datasource.limit-affects-dml"
;
public
static
final
int
METADATA_FETCH_SIZE
=
1000
;
public
static
final
String
DATA_SOURCE_PROPERTY_USER
=
"user"
;
//NON-NLS-1
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/DBUtils.java
浏览文件 @
65a49e34
...
...
@@ -930,7 +930,10 @@ public final class DBUtils {
// or some DML. For DML statements we mustn't set limits
// because it sets update rows limit [SQL Server]
boolean
selectQuery
=
sqlQuery
.
getType
()
==
SQLQueryType
.
SELECT
&&
sqlQuery
.
isPlainSelect
();
final
boolean
hasLimits
=
selectQuery
&&
offset
>=
0
&&
maxRows
>
0
;
final
boolean
hasLimits
=
offset
>
0
||
(
selectQuery
&&
maxRows
>
0
);
// This is a flag for any potential SELECT query
boolean
possiblySelect
=
sqlQuery
.
getType
()
==
SQLQueryType
.
SELECT
||
sqlQuery
.
getType
()
==
SQLQueryType
.
UNKNOWN
;
boolean
limitAffectsDML
=
Boolean
.
TRUE
.
equals
(
session
.
getDataSource
().
getDataSourceFeature
(
DBConstants
.
FEATURE_LIMIT_AFFECTS_DML
));
DBCQueryTransformer
limitTransformer
=
null
,
fetchAllTransformer
=
null
;
if
(
selectQuery
)
{
...
...
@@ -940,7 +943,7 @@ public final class DBUtils {
if
(
session
.
getDataSource
().
getContainer
().
getPreferenceStore
().
getBoolean
(
ModelPreferences
.
RESULT_SET_MAX_ROWS_USE_SQL
))
{
limitTransformer
=
transformProvider
.
createQueryTransformer
(
DBCQueryTransformType
.
RESULT_SET_LIMIT
);
}
}
else
if
(
offset
<=
0
&&
maxRows
<=
0
)
{
}
else
if
(
maxRows
<=
0
)
{
fetchAllTransformer
=
transformProvider
.
createQueryTransformer
(
DBCQueryTransformType
.
FETCH_ALL_TABLE
);
}
}
...
...
@@ -961,7 +964,7 @@ public final class DBUtils {
makeStatement
(
session
,
queryText
,
hasLimits
);
dbStat
.
setStatementSource
(
executionSource
);
if
(
hasLimits
||
offset
>
0
)
{
if
(
offset
>
0
||
hasLimits
||
(
possiblySelect
&&
maxRows
>
0
&&
!
limitAffectsDML
)
)
{
if
(
limitTransformer
==
null
)
{
// Set explicit limit - it is safe because we pretty sure that this is a plain SELECT query
dbStat
.
setLimit
(
offset
,
maxRows
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录