Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
bf30d4ea
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,发现更多精彩内容 >>
提交
bf30d4ea
编写于
7月 07, 2018
作者:
S
serge-rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#3731 PG: domain types value type resolution fix (date/time/timestamp)
上级
f383e44d
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
61 addition
and
4 deletion
+61
-4
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreDataType.java
...g/jkiss/dbeaver/ext/postgresql/model/PostgreDataType.java
+24
-4
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreDataTypeCache.java
...ss/dbeaver/ext/postgresql/model/PostgreDataTypeCache.java
+10
-0
plugins/org.jkiss.dbeaver.model/OSGI-INF/l10n/bundle.properties
...s/org.jkiss.dbeaver.model/OSGI-INF/l10n/bundle.properties
+1
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/exec/JDBCColumnMetaData.java
...kiss/dbeaver/model/impl/jdbc/exec/JDBCColumnMetaData.java
+22
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/struct/JDBCDataType.java
...rg/jkiss/dbeaver/model/impl/jdbc/struct/JDBCDataType.java
+4
-0
未找到文件。
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreDataType.java
浏览文件 @
bf30d4ea
...
...
@@ -221,6 +221,20 @@ public class PostgreDataType extends JDBCDataType<PostgreSchema> implements Post
this
.
enumValues
=
null
;
}
void
resolveValueTypeFromBaseType
(
DBRProgressMonitor
monitor
)
{
if
(
baseTypeId
>
0
)
{
PostgreDataType
baseType
=
getBaseType
(
monitor
);
if
(
baseType
==
null
)
{
log
.
debug
(
"Can't find type '"
+
getFullTypeName
()
+
"' base type "
+
baseTypeId
);
}
else
{
if
(
getTypeID
()
!=
baseType
.
getTypeID
())
{
//log.debug(getFullTypeName() + " type ID resolved to " + baseType.getTypeID());
setTypeID
(
baseType
.
getTypeID
());
}
}
}
}
public
boolean
isAlias
()
{
return
alias
;
}
...
...
@@ -291,6 +305,7 @@ public class PostgreDataType extends JDBCDataType<PostgreSchema> implements Post
}
@Override
@Property
(
category
=
CAT_MAIN
,
viewable
=
false
,
order
=
9
)
public
long
getObjectId
()
{
return
typeId
;
}
...
...
@@ -642,12 +657,17 @@ public class PostgreDataType extends JDBCDataType<PostgreSchema> implements Post
valueType
=
Types
.
STRUCT
;
break
;
case
D:
if
(
name
.
startsWith
(
"timestamp"
))
{
valueType
=
Types
.
TIMESTAMP
;
}
else
if
(
name
.
startsWith
(
"date"
))
{
if
(
typeLength
==
4
)
{
valueType
=
Types
.
DATE
;
}
else
if
(
typeLength
==
8
)
{
if
(
name
.
startsWith
(
"timestamp"
))
{
valueType
=
Types
.
TIMESTAMP
;
}
else
{
valueType
=
Types
.
TIME
;
}
}
else
{
valueType
=
Types
.
TIME
;
// Weird
valueType
=
Types
.
TIMESTAMP
;
}
break
;
case
N:
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreDataTypeCache.java
浏览文件 @
bf30d4ea
...
...
@@ -32,6 +32,7 @@ import org.jkiss.dbeaver.model.runtime.DBRProgressMonitor;
import
org.jkiss.utils.LongKeyMap
;
import
java.sql.SQLException
;
import
java.util.Iterator
;
import
java.util.List
;
import
java.util.Map
;
...
...
@@ -131,6 +132,15 @@ public class PostgreDataTypeCache extends JDBCObjectCache<PostgreSchema, Postgre
return
PostgreDataType
.
readDataType
(
session
,
owner
,
dbResult
);
}
@Override
protected
void
invalidateObjects
(
DBRProgressMonitor
monitor
,
PostgreSchema
postgreSchema
,
Iterator
<
PostgreDataType
>
objectIter
)
{
// Resolve value type IDs (#3731)
while
(
objectIter
.
hasNext
())
{
PostgreDataType
dt
=
objectIter
.
next
();
dt
.
resolveValueTypeFromBaseType
(
monitor
);
}
}
public
PostgreDataType
getDataType
(
long
oid
)
{
return
dataTypeMap
.
get
(
oid
);
}
...
...
plugins/org.jkiss.dbeaver.model/OSGI-INF/l10n/bundle.properties
浏览文件 @
bf30d4ea
...
...
@@ -41,6 +41,7 @@ meta.org.jkiss.dbeaver.model.impl.jdbc.exec.JDBCColumnMetaData.schemaName.name=S
meta.org.jkiss.dbeaver.model.impl.jdbc.exec.JDBCColumnMetaData.scale.name
=
Scale
meta.org.jkiss.dbeaver.model.impl.jdbc.exec.JDBCColumnMetaData.precision.name
=
Precision
meta.org.jkiss.dbeaver.model.impl.jdbc.exec.JDBCColumnMetaData.maxLength.name
=
Max Length
meta.org.jkiss.dbeaver.model.impl.jdbc.exec.JDBCColumnMetaData.jdbcType.name
=
JDBC Type
meta.org.jkiss.dbeaver.model.impl.local.LocalResultSetColumn.ordinalPosition.name
=
#
meta.org.jkiss.dbeaver.model.impl.local.LocalResultSetColumn.label.name=Label
meta.org.jkiss.dbeaver.model.impl.local.LocalResultSetColumn.typeName.name
=
Type
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/exec/JDBCColumnMetaData.java
浏览文件 @
bf30d4ea
...
...
@@ -33,8 +33,11 @@ import org.jkiss.dbeaver.model.sql.SQLDialect;
import
org.jkiss.dbeaver.model.struct.DBSDataType
;
import
org.jkiss.utils.CommonUtils
;
import
java.lang.reflect.Field
;
import
java.lang.reflect.Modifier
;
import
java.sql.ResultSetMetaData
;
import
java.sql.SQLException
;
import
java.sql.Types
;
/**
* JDBCColumnMetaData
...
...
@@ -275,6 +278,25 @@ public class JDBCColumnMetaData implements DBCAttributeMetaData {
return
typeID
;
}
@NotNull
@Property
(
viewable
=
true
,
category
=
PROP_CATEGORY_COLUMN
,
order
=
23
)
public
String
getJdbcType
()
{
int
typeID
=
getTypeID
();
try
{
for
(
Field
field
:
Types
.
class
.
getFields
())
{
if
((
field
.
getModifiers
()
&
Modifier
.
STATIC
)
!=
0
&&
field
.
getType
()
==
Integer
.
TYPE
)
{
Integer
value
=
(
Integer
)
field
.
get
(
null
);
if
(
value
!=
null
&&
typeID
==
value
)
{
return
field
.
getName
();
}
}
}
}
catch
(
Exception
e
)
{
log
.
error
(
e
);
}
return
String
.
valueOf
(
typeID
);
}
@Override
public
DBPDataKind
getDataKind
()
{
return
dataKind
;
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/struct/JDBCDataType.java
浏览文件 @
bf30d4ea
...
...
@@ -87,6 +87,10 @@ public class JDBCDataType<OWNER extends DBSObject> implements DBSDataType
return
valueType
;
}
protected
void
setTypeID
(
int
valueType
)
{
this
.
valueType
=
valueType
;
}
@NotNull
@Override
public
String
getName
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录