Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
a068e5c5
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,发现更多精彩内容 >>
提交
a068e5c5
编写于
6月 30, 2018
作者:
S
Serge Rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#3694 Oracle tablespace stats (user & available sizes)
Former-commit-id:
28bc1504
上级
3250bf70
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
66 addition
and
19 deletion
+66
-19
plugins/org.jkiss.dbeaver.ext.oracle/OSGI-INF/l10n/bundle.properties
....jkiss.dbeaver.ext.oracle/OSGI-INF/l10n/bundle.properties
+2
-0
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/model/OracleTablespace.java
.../org/jkiss/dbeaver/ext/oracle/model/OracleTablespace.java
+64
-19
未找到文件。
plugins/org.jkiss.dbeaver.ext.oracle/OSGI-INF/l10n/bundle.properties
浏览文件 @
a068e5c5
...
...
@@ -318,6 +318,8 @@ meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablePhysical.realRowCount.name=Re
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablePhysical.realRowCount.description
=
Actual row count
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablePhysical.tablespace.name
=
Tablespace
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablespace.name.name
=
Name
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablespace.availableSize.name
=
Available Size
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablespace.usedSize.name
=
Used Size
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablespace.blockSize.name
=
Block Size
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablespace.initialExtent.name
=
Initial Extent
meta.org.jkiss.dbeaver.ext.oracle.model.OracleTablespace.nextExtent.name
=
Next Extent
...
...
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/model/OracleTablespace.java
浏览文件 @
a068e5c5
...
...
@@ -20,9 +20,10 @@ import org.jkiss.code.NotNull;
import
org.jkiss.code.Nullable
;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.model.DBPRefreshableObject
;
import
org.jkiss.dbeaver.model.DBUtils
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCResultSet
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCSession
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCStatement
;
import
org.jkiss.dbeaver.model.impl.jdbc.JDBCUtils
;
import
org.jkiss.dbeaver.model.impl.jdbc.cache.JDBCObjectCache
;
...
...
@@ -102,6 +103,8 @@ public class OracleTablespace extends OracleGlobalObject implements DBPRefreshab
private
boolean
defTableCompression
;
private
Retention
retention
;
private
boolean
bigFile
;
private
volatile
Long
availableSize
;
private
volatile
Long
usedSize
;
final
FileCache
fileCache
=
new
FileCache
();
final
SegmentCache
segmentCache
=
new
SegmentCache
();
...
...
@@ -138,109 +141,125 @@ public class OracleTablespace extends OracleGlobalObject implements DBPRefreshab
return
name
;
}
@Property
(
viewable
=
true
,
editable
=
true
,
order
=
2
)
@Property
(
viewable
=
true
,
order
=
4
)
public
Long
getAvailableSize
(
DBRProgressMonitor
monitor
)
throws
DBException
{
if
(
availableSize
==
null
)
{
loadSizes
(
monitor
);
}
return
availableSize
;
}
@Property
(
viewable
=
true
,
order
=
5
)
public
Long
getUsedSize
(
DBRProgressMonitor
monitor
)
throws
DBException
{
if
(
usedSize
==
null
)
{
loadSizes
(
monitor
);
}
return
usedSize
;
}
@Property
(
viewable
=
true
,
editable
=
true
,
order
=
22
)
public
long
getBlockSize
()
{
return
blockSize
;
}
@Property
(
editable
=
true
,
order
=
3
)
@Property
(
editable
=
true
,
order
=
2
3
)
public
long
getInitialExtent
()
{
return
initialExtent
;
}
@Property
(
editable
=
true
,
order
=
4
)
@Property
(
editable
=
true
,
order
=
2
4
)
public
long
getNextExtent
()
{
return
nextExtent
;
}
@Property
(
editable
=
true
,
order
=
5
)
@Property
(
editable
=
true
,
order
=
2
5
)
public
long
getMinExtents
()
{
return
minExtents
;
}
@Property
(
editable
=
true
,
order
=
6
)
@Property
(
editable
=
true
,
order
=
2
6
)
public
long
getMaxExtents
()
{
return
maxExtents
;
}
@Property
(
editable
=
true
,
order
=
7
)
@Property
(
editable
=
true
,
order
=
2
7
)
public
long
getPctIncrease
()
{
return
pctIncrease
;
}
@Property
(
editable
=
true
,
order
=
8
)
@Property
(
editable
=
true
,
order
=
2
8
)
public
long
getMinExtLen
()
{
return
minExtLen
;
}
@Property
(
viewable
=
true
,
editable
=
true
,
order
=
9
)
@Property
(
viewable
=
true
,
editable
=
true
,
order
=
2
9
)
public
Status
getStatus
()
{
return
status
;
}
@Property
(
editable
=
true
,
order
=
1
0
)
@Property
(
editable
=
true
,
order
=
3
0
)
public
Contents
getContents
()
{
return
contents
;
}
@Property
(
editable
=
true
,
order
=
1
1
)
@Property
(
editable
=
true
,
order
=
3
1
)
public
Logging
isLogging
()
{
return
logging
;
}
@Property
(
editable
=
true
,
order
=
1
2
)
@Property
(
editable
=
true
,
order
=
3
2
)
public
boolean
isForceLogging
()
{
return
forceLogging
;
}
@Property
(
editable
=
true
,
order
=
1
3
)
@Property
(
editable
=
true
,
order
=
3
3
)
public
ExtentManagement
getExtentManagement
()
{
return
extentManagement
;
}
@Property
(
editable
=
true
,
order
=
1
4
)
@Property
(
editable
=
true
,
order
=
3
4
)
public
AllocationType
getAllocationType
()
{
return
allocationType
;
}
@Property
(
editable
=
true
,
order
=
1
5
)
@Property
(
editable
=
true
,
order
=
3
5
)
public
boolean
isPluggedIn
()
{
return
pluggedIn
;
}
@Property
(
editable
=
true
,
order
=
1
6
)
@Property
(
editable
=
true
,
order
=
3
6
)
public
SegmentSpaceManagement
getSegmentSpaceManagement
()
{
return
segmentSpaceManagement
;
}
@Property
(
editable
=
true
,
order
=
1
7
)
@Property
(
editable
=
true
,
order
=
3
7
)
public
boolean
isDefTableCompression
()
{
return
defTableCompression
;
}
@Property
(
editable
=
true
,
order
=
1
8
)
@Property
(
editable
=
true
,
order
=
3
8
)
public
Retention
getRetention
()
{
return
retention
;
}
@Property
(
editable
=
true
,
order
=
1
9
)
@Property
(
editable
=
true
,
order
=
3
9
)
public
boolean
isBigFile
()
{
return
bigFile
;
...
...
@@ -276,6 +295,32 @@ public class OracleTablespace extends OracleGlobalObject implements DBPRefreshab
return
this
;
}
private
void
loadSizes
(
DBRProgressMonitor
monitor
)
throws
DBException
{
try
(
final
JDBCSession
session
=
DBUtils
.
openMetaSession
(
monitor
,
getDataSource
(),
"Load tablespace '"
+
getName
()
+
"' statistics"
))
{
try
(
final
JDBCPreparedStatement
dbStat
=
session
.
prepareStatement
(
"SELECT SUM(F.BYTES) AVAILABLE_SPACE,SUM(S.BYTES) USED_SPACE\n"
+
"FROM SYS.DBA_TABLESPACES T\n"
+
"LEFT JOIN SYS.DBA_DATA_FILES F ON T.TABLESPACE_NAME = F.TABLESPACE_NAME\n"
+
"LEFT JOIN SYS.DBA_SEGMENTS S ON T.TABLESPACE_NAME = S.TABLESPACE_NAME\n"
+
"WHERE T.TABLESPACE_NAME=?"
))
{
dbStat
.
setString
(
1
,
getName
());
try
(
JDBCResultSet
dbResult
=
dbStat
.
executeQuery
())
{
if
(
dbResult
.
next
())
{
availableSize
=
dbResult
.
getLong
(
1
);
usedSize
=
dbResult
.
getLong
(
2
);
}
else
{
availableSize
=
0L
;
usedSize
=
0L
;
}
}
}
catch
(
SQLException
e
)
{
throw
new
DBException
(
"Can't read tablespace statistics"
,
e
,
getDataSource
());
}
}
}
static
class
FileCache
extends
JDBCObjectCache
<
OracleTablespace
,
OracleDataFile
>
{
@Override
protected
JDBCStatement
prepareObjectsStatement
(
@NotNull
JDBCSession
session
,
@NotNull
OracleTablespace
owner
)
throws
SQLException
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录