Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
dea98a3d
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,发现更多精彩内容 >>
提交
dea98a3d
编写于
12月 20, 2019
作者:
S
Serge Rider
提交者:
GitHub
12月 20, 2019
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #7427 from SergDzh/patch-4
Oracle Session New Tab Former-commit-id:
d71cbc4e
上级
6a66b24c
a5568680
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
69 addition
and
0 deletion
+69
-0
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/model/session/OracleServerExecutePlan.java
...ver/ext/oracle/model/session/OracleServerExecutePlan.java
+41
-0
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/model/session/OracleServerSessionManager.java
.../ext/oracle/model/session/OracleServerSessionManager.java
+28
-0
未找到文件。
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/model/session/OracleServerExecutePlan.java
0 → 100644
浏览文件 @
dea98a3d
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2019 SergDzh (jurasik@bigmir.net)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
org.jkiss.dbeaver.ext.oracle.model.session
;
import
org.jkiss.dbeaver.model.DBPObject
;
import
org.jkiss.dbeaver.model.impl.jdbc.JDBCUtils
;
import
org.jkiss.dbeaver.model.meta.Property
;
import
java.sql.ResultSet
;
/**
* Plan
*/
public
class
OracleServerExecutePlan
implements
DBPObject
{
private
String
plan
;
public
OracleServerExecutePlan
(
ResultSet
dbResult
)
{
this
.
plan
=
JDBCUtils
.
safeGetString
(
dbResult
,
"PLAN_TABLE_OUTPUT"
);
}
@Property
(
viewable
=
true
,
order
=
1
)
public
String
getPlan
()
{
return
plan
;
}
}
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/model/session/OracleServerSessionManager.java
浏览文件 @
dea98a3d
...
...
@@ -154,6 +154,34 @@ public class OracleServerSessionManager implements DBAServerSessionManager<Oracl
return
OracleServerLongOp
.
class
;
}
});
extDetails
.
add
(
new
AbstractServerSessionDetails
(
"Display Exec Plan"
,
"Displays execute plan from dbms_xplan by SqlId and ChildNumber"
,
DBIcon
.
TYPE_TEXT
)
{
@Override
public
List
<
OracleServerExecutePlan
>
getSessionDetails
(
DBCSession
session
,
DBAServerSession
serverSession
)
throws
DBException
{
try
{
try
(
JDBCPreparedStatement
dbStat
=
((
JDBCSession
)
session
).
prepareStatement
(
"SELECT PLAN_TABLE_OUTPUT FROM TABLE(dbms_xplan.display_cursor(sql_id => ?, cursor_child_no => ?))"
))
{
dbStat
.
setString
(
1
,
((
OracleServerSession
)
serverSession
).
getSqlId
());
dbStat
.
setLong
(
2
,
((
OracleServerSession
)
serverSession
).
getSqlChildNumber
());
try
(
JDBCResultSet
dbResult
=
dbStat
.
executeQuery
())
{
List
<
OracleServerExecutePlan
>
ExecutePlan
=
new
ArrayList
<>();
while
(
dbResult
.
next
())
{
ExecutePlan
.
add
(
new
OracleServerExecutePlan
(
dbResult
));
}
return
ExecutePlan
;
}
}
}
catch
(
SQLException
e
)
{
throw
new
DBException
(
e
,
session
.
getDataSource
());
}
}
@Override
public
Class
<?
extends
DBPObject
>
getDetailsType
()
{
return
OracleServerExecutePlan
.
class
;
}
});
return
extDetails
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录