Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
5526a461
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,发现更多精彩内容 >>
提交
5526a461
编写于
11月 18, 2018
作者:
S
serge-rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#4461 PostgreSQL + GIS: support new geometry values create
上级
94fd026b
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
70 addition
and
5 deletion
+70
-5
plugins/org.jkiss.dbeaver.data.gis/META-INF/MANIFEST.MF
plugins/org.jkiss.dbeaver.data.gis/META-INF/MANIFEST.MF
+2
-1
plugins/org.jkiss.dbeaver.data.gis/src/org/jkiss/dbeaver/model/gis/GisAttribute.java
...ata.gis/src/org/jkiss/dbeaver/model/gis/GisAttribute.java
+28
-0
plugins/org.jkiss.dbeaver.data.gis/src/org/jkiss/dbeaver/ui/data/managers/GeometryInlineEditor.java
.../jkiss/dbeaver/ui/data/managers/GeometryInlineEditor.java
+14
-3
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreTableColumn.java
...kiss/dbeaver/ext/postgresql/model/PostgreTableColumn.java
+26
-1
未找到文件。
plugins/org.jkiss.dbeaver.data.gis/META-INF/MANIFEST.MF
浏览文件 @
5526a461
...
...
@@ -11,4 +11,5 @@ Require-Bundle: org.jkiss.dbeaver.model,
org.eclipse.jface,
com.vividsolutions.jts
Bundle-ClassPath: .
Export-Package: org.jkiss.dbeaver.data.gis.handlers
Export-Package: org.jkiss.dbeaver.data.gis.handlers,
org.jkiss.dbeaver.model.gis
plugins/org.jkiss.dbeaver.data.gis/src/org/jkiss/dbeaver/model/gis/GisAttribute.java
0 → 100644
浏览文件 @
5526a461
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org)
*
* 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.model.gis
;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
/**
* GisAttribute.
*/
public
interface
GisAttribute
{
int
getAttributeSRID
(
DBRProgressMonitor
monitor
);
}
plugins/org.jkiss.dbeaver.data.gis/src/org/jkiss/dbeaver/ui/data/managers/GeometryInlineEditor.java
浏览文件 @
5526a461
...
...
@@ -19,11 +19,14 @@ package org.jkiss.dbeaver.ui.data.managers;
import
com.vividsolutions.jts.geom.Geometry
;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.model.exec.DBCException
;
import
org.jkiss.dbeaver.model.gis.GisAttribute
;
import
org.jkiss.dbeaver.model.runtime.VoidProgressMonitor
;
import
org.jkiss.dbeaver.model.struct.DBSTypedObject
;
import
org.jkiss.dbeaver.ui.data.IValueController
;
import
org.jkiss.dbeaver.ui.data.editors.StringInlineEditor
;
/**
* G
eometryInlineEditor
.
* G
isAttribute
.
* Edits value as string. Also manager SRID.
*/
public
class
GeometryInlineEditor
extends
StringInlineEditor
{
...
...
@@ -40,13 +43,21 @@ public class GeometryInlineEditor extends StringInlineEditor {
if
(
value
instanceof
Geometry
)
{
this
.
valueSRID
=
((
Geometry
)
value
).
getSRID
();
}
if
(
valueSRID
==
0
)
{
DBSTypedObject
column
=
valueController
.
getValueType
();
if
(
column
instanceof
GisAttribute
)
{
valueSRID
=
((
GisAttribute
)
column
).
getAttributeSRID
(
new
VoidProgressMonitor
());
}
}
}
@Override
public
Object
extractEditorValue
()
throws
DBCException
{
Object
geometry
=
super
.
extractEditorValue
();
if
(
geometry
instanceof
Geometry
&&
valueSRID
!=
0
)
{
((
Geometry
)
geometry
).
setSRID
(
valueSRID
);
if
(
geometry
instanceof
Geometry
)
{
if
(
valueSRID
!=
0
)
{
((
Geometry
)
geometry
).
setSRID
(
valueSRID
);
}
}
return
geometry
;
}
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreTableColumn.java
浏览文件 @
5526a461
...
...
@@ -17,17 +17,27 @@
package
org.jkiss.dbeaver.ext.postgresql.model
;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.Log
;
import
org.jkiss.dbeaver.ext.postgresql.PostgreUtils
;
import
org.jkiss.dbeaver.model.DBUtils
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCResultSet
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCSession
;
import
org.jkiss.dbeaver.model.gis.GisAttribute
;
import
org.jkiss.dbeaver.model.impl.jdbc.JDBCUtils
;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
import
java.sql.SQLException
;
import
java.util.Collection
;
/**
* PostgreTableColumn
*/
public
class
PostgreTableColumn
extends
PostgreAttribute
<
PostgreTableBase
>
implements
PostgrePermissionsOwner
public
class
PostgreTableColumn
extends
PostgreAttribute
<
PostgreTableBase
>
implements
PostgrePermissionsOwner
,
GisAttribute
{
private
static
final
Log
log
=
Log
.
getLog
(
PostgreTableColumn
.
class
);
private
int
srid
=
-
1
;
public
PostgreTableColumn
(
PostgreTableBase
table
)
{
super
(
table
);
}
...
...
@@ -51,4 +61,19 @@ public class PostgreTableColumn extends PostgreAttribute<PostgreTableBase> imple
return
PostgreUtils
.
extractPermissionsFromACL
(
monitor
,
this
,
getAcl
());
}
@Override
public
int
getAttributeSRID
(
DBRProgressMonitor
monitor
)
{
if
(
srid
==
-
1
)
{
try
(
JDBCSession
session
=
DBUtils
.
openMetaSession
(
monitor
,
this
,
"Load table inheritance info"
))
{
Object
sridValue
=
JDBCUtils
.
queryObject
(
session
,
"SELECT Find_SRID('"
+
getSchema
().
getName
()
+
"', '"
+
getTable
().
getName
()
+
"', '"
+
getName
()
+
"')"
);
if
(
sridValue
instanceof
Number
)
{
srid
=
((
Number
)
sridValue
).
intValue
();
}
}
catch
(
SQLException
e
)
{
log
.
debug
(
"Error reading attribute "
+
getName
()
+
" SRID"
,
e
);
srid
=
0
;
}
}
return
srid
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录