Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
9edf59b0
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,发现更多精彩内容 >>
提交
9edf59b0
编写于
9月 23, 2016
作者:
S
serge-rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#711 PG JSON support
上级
8b0e14f0
变更
12
隐藏空白更改
内联
并排
Showing
12 changed file
with
200 addition
and
27 deletion
+200
-27
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/data/OracleContentOpaque.java
...rg/jkiss/dbeaver/ext/oracle/data/OracleContentOpaque.java
+1
-1
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/data/OracleContentXML.java
...c/org/jkiss/dbeaver/ext/oracle/data/OracleContentXML.java
+1
-1
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.xml
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.xml
+1
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/PostgreConstants.java
...rc/org/jkiss/dbeaver/ext/postgresql/PostgreConstants.java
+2
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreDataType.java
...g/jkiss/dbeaver/ext/postgresql/model/PostgreDataType.java
+6
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/data/PostgreContentJSON.java
...dbeaver/ext/postgresql/model/data/PostgreContentJSON.java
+69
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/data/PostgreJSONValueHandler.java
...er/ext/postgresql/model/data/PostgreJSONValueHandler.java
+53
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/data/PostgreValueHandlerProvider.java
...xt/postgresql/model/data/PostgreValueHandlerProvider.java
+9
-3
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/data/AbstractContent.java
...rc/org/jkiss/dbeaver/model/impl/data/AbstractContent.java
+52
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentAbstract.java
...iss/dbeaver/model/impl/jdbc/data/JDBCContentAbstract.java
+4
-20
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentChars.java
.../jkiss/dbeaver/model/impl/jdbc/data/JDBCContentChars.java
+1
-1
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentXML.java
...rg/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentXML.java
+1
-1
未找到文件。
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/data/OracleContentOpaque.java
浏览文件 @
9edf59b0
...
...
@@ -100,7 +100,7 @@ public abstract class OracleContentOpaque<OPAQUE_TYPE extends Object> extends JD
}
else
if
(
opaque
!=
null
)
{
preparedStatement
.
setObject
(
paramIndex
,
opaque
);
}
else
{
preparedStatement
.
setNull
(
paramIndex
+
1
,
java
.
sql
.
Types
.
SQLXML
);
preparedStatement
.
setNull
(
paramIndex
,
java
.
sql
.
Types
.
SQLXML
);
}
}
catch
(
IOException
e
)
{
...
...
plugins/org.jkiss.dbeaver.ext.oracle/src/org/jkiss/dbeaver/ext/oracle/data/OracleContentXML.java
浏览文件 @
9edf59b0
...
...
@@ -65,7 +65,7 @@ public class OracleContentXML extends JDBCContentXML {
xmlObject
);
}
}
else
{
preparedStatement
.
setNull
(
paramIndex
+
1
,
java
.
sql
.
Types
.
SQLXML
);
preparedStatement
.
setNull
(
paramIndex
,
java
.
sql
.
Types
.
SQLXML
);
}
}
catch
(
SQLException
e
)
{
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.xml
浏览文件 @
9edf59b0
...
...
@@ -195,6 +195,7 @@
<type
standard=
"ARRAY"
/>
<type
standard=
"STRUCT"
/>
<type
name=
"HSTORE"
/>
<type
name=
"JSONB"
/>
</provider>
</extension>
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/PostgreConstants.java
浏览文件 @
9edf59b0
...
...
@@ -66,6 +66,8 @@ public class PostgreConstants {
"oid"
,
"oid"
,
"Row identifier"
,
false
);
public
static
final
String
TYPE_HSTORE
=
"hstore"
;
public
static
final
String
TYPE_JSON
=
"json"
;
public
static
final
String
TYPE_JSONB
=
"jsonb"
;
public
static
final
String
HANDLER_SSL
=
"postgre_ssl"
;
public
static
final
String
EC_PERMISSION_DENIED
=
"42501"
;
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreDataType.java
浏览文件 @
9edf59b0
...
...
@@ -21,6 +21,7 @@ import org.jkiss.code.NotNull;
import
org.jkiss.code.Nullable
;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.Log
;
import
org.jkiss.dbeaver.ext.postgresql.PostgreConstants
;
import
org.jkiss.dbeaver.ext.postgresql.PostgreUtils
;
import
org.jkiss.dbeaver.model.DBPDataKind
;
import
org.jkiss.dbeaver.model.DBPEvaluationContext
;
...
...
@@ -128,6 +129,11 @@ public class PostgreDataType extends JDBCDataType<PostgreSchema> implements Post
}
this
.
dataKind
=
JDBCDataSource
.
getDataKind
(
getName
(),
valueType
);
if
(
this
.
dataKind
==
DBPDataKind
.
OBJECT
)
{
if
(
PostgreConstants
.
TYPE_JSONB
.
equals
(
name
)
||
PostgreConstants
.
TYPE_JSON
.
equals
(
name
))
{
this
.
dataKind
=
DBPDataKind
.
CONTENT
;
}
}
this
.
ownerId
=
JDBCUtils
.
safeGetLong
(
dbResult
,
"typowner"
);
this
.
isByValue
=
JDBCUtils
.
safeGetBoolean
(
dbResult
,
"typbyval"
);
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/data/PostgreContentJSON.java
0 → 100644
浏览文件 @
9edf59b0
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2010-2016 Serge Rieder (serge@jkiss.org)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License (version 2)
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package
org.jkiss.dbeaver.ext.postgresql.model.data
;
import
org.jkiss.code.NotNull
;
import
org.jkiss.dbeaver.model.DBPDataSource
;
import
org.jkiss.dbeaver.model.exec.DBCException
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCSession
;
import
org.jkiss.dbeaver.model.impl.jdbc.data.JDBCContentChars
;
import
org.jkiss.dbeaver.model.struct.DBSTypedObject
;
import
org.jkiss.dbeaver.utils.MimeTypes
;
import
java.sql.SQLException
;
import
java.sql.Types
;
/**
* JSON content
*/
public
class
PostgreContentJSON
extends
JDBCContentChars
{
public
PostgreContentJSON
(
DBPDataSource
dataSource
,
String
json
)
{
super
(
dataSource
,
json
);
}
@NotNull
@Override
public
String
getContentType
()
{
return
MimeTypes
.
TEXT_JSON
;
}
@Override
public
void
bindParameter
(
JDBCSession
session
,
JDBCPreparedStatement
preparedStatement
,
DBSTypedObject
columnType
,
int
paramIndex
)
throws
DBCException
{
try
{
if
(
data
!=
null
)
{
preparedStatement
.
setObject
(
paramIndex
,
data
,
Types
.
OTHER
);
}
else
{
preparedStatement
.
setNull
(
paramIndex
,
columnType
.
getTypeID
());
}
}
catch
(
SQLException
e
)
{
throw
new
DBCException
(
e
,
session
.
getDataSource
());
}
}
}
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/data/PostgreJSONValueHandler.java
0 → 100644
浏览文件 @
9edf59b0
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2010-2016 Serge Rieder (serge@jkiss.org)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License (version 2)
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package
org.jkiss.dbeaver.ext.postgresql.model.data
;
import
org.jkiss.code.NotNull
;
import
org.jkiss.dbeaver.model.data.DBDContent
;
import
org.jkiss.dbeaver.model.exec.DBCException
;
import
org.jkiss.dbeaver.model.exec.DBCSession
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCResultSet
;
import
org.jkiss.dbeaver.model.impl.jdbc.data.handlers.JDBCContentValueHandler
;
import
org.jkiss.dbeaver.model.struct.DBSTypedObject
;
import
java.sql.SQLException
;
/**
* PostgreJSONValueHandler
*/
public
class
PostgreJSONValueHandler
extends
JDBCContentValueHandler
{
public
static
final
PostgreJSONValueHandler
INSTANCE
=
new
PostgreJSONValueHandler
();
@Override
protected
DBDContent
fetchColumnValue
(
DBCSession
session
,
JDBCResultSet
resultSet
,
DBSTypedObject
type
,
int
index
)
throws
SQLException
{
String
json
=
resultSet
.
getString
(
index
);
return
new
PostgreContentJSON
(
session
.
getDataSource
(),
json
);
}
@Override
public
DBDContent
getValueFromObject
(
@NotNull
DBCSession
session
,
@NotNull
DBSTypedObject
type
,
Object
object
,
boolean
copy
)
throws
DBCException
{
if
(
object
==
null
)
{
return
new
PostgreContentJSON
(
session
.
getDataSource
(),
null
);
}
else
if
(
object
instanceof
PostgreContentJSON
)
{
return
copy
?
(
PostgreContentJSON
)((
PostgreContentJSON
)
object
).
cloneValue
(
session
.
getProgressMonitor
())
:
(
PostgreContentJSON
)
object
;
}
return
super
.
getValueFromObject
(
session
,
type
,
object
,
copy
);
}
}
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/data/PostgreValueHandlerProvider.java
浏览文件 @
9edf59b0
...
...
@@ -49,10 +49,16 @@ public class PostgreValueHandlerProvider implements DBDValueHandlerProvider {
return
PostgreArrayValueHandler
.
INSTANCE
;
}
else
if
(
typeID
==
Types
.
STRUCT
)
{
return
PostgreStructValueHandler
.
INSTANCE
;
}
else
if
(
typedObject
.
getTypeName
().
equalsIgnoreCase
(
PostgreConstants
.
TYPE_HSTORE
))
{
return
PostgreHStoreValueHandler
.
INSTANCE
;
}
else
{
return
null
;
switch
(
typedObject
.
getTypeName
())
{
case
PostgreConstants
.
TYPE_JSONB
:
case
PostgreConstants
.
TYPE_JSON
:
return
PostgreJSONValueHandler
.
INSTANCE
;
case
PostgreConstants
.
TYPE_HSTORE
:
return
PostgreHStoreValueHandler
.
INSTANCE
;
default
:
return
null
;
}
}
}
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/data/AbstractContent.java
0 → 100644
浏览文件 @
9edf59b0
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2010-2016 Serge Rieder (serge@jkiss.org)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License (version 2)
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package
org.jkiss.dbeaver.model.impl.data
;
import
org.jkiss.dbeaver.model.DBConstants
;
import
org.jkiss.dbeaver.model.DBPDataSource
;
import
org.jkiss.dbeaver.model.data.DBDContent
;
import
org.jkiss.dbeaver.model.data.DBDDisplayFormat
;
/**
* AbstractContent
*
* @author Serge Rider
*/
public
abstract
class
AbstractContent
implements
DBDContent
{
protected
final
DBPDataSource
dataSource
;
protected
AbstractContent
(
DBPDataSource
dataSource
)
{
this
.
dataSource
=
dataSource
;
}
@Override
public
void
resetContents
()
{
// do nothing
}
@Override
public
String
toString
()
{
String
displayString
=
getDisplayString
(
DBDDisplayFormat
.
UI
);
return
displayString
==
null
?
DBConstants
.
NULL_VALUE_LABEL
:
displayString
;
}
}
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentAbstract.java
浏览文件 @
9edf59b0
...
...
@@ -17,43 +17,27 @@
*/
package
org.jkiss.dbeaver.model.impl.jdbc.data
;
import
org.jkiss.dbeaver.model.DBConstants
;
import
org.jkiss.dbeaver.model.DBPDataSource
;
import
org.jkiss.dbeaver.model.data.DBDContent
;
import
org.jkiss.dbeaver.model.data.DBDDisplayFormat
;
import
org.jkiss.dbeaver.model.data.DBDValueCloneable
;
import
org.jkiss.dbeaver.model.exec.DBCException
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCSession
;
import
org.jkiss.dbeaver.model.impl.data.AbstractContent
;
import
org.jkiss.dbeaver.model.struct.DBSTypedObject
;
/**
* JDBC
BLOB
* JDBC
ContentAbstract
*
* @author Serge Rider
*/
public
abstract
class
JDBCContentAbstract
implements
DBDContent
,
DBDValueCloneable
{
protected
final
DBPDataSource
dataSource
;
public
abstract
class
JDBCContentAbstract
extends
AbstractContent
implements
DBDValueCloneable
{
protected
JDBCContentAbstract
(
DBPDataSource
dataSource
)
{
this
.
dataSource
=
dataSource
;
super
(
dataSource
)
;
}
public
abstract
void
bindParameter
(
JDBCSession
session
,
JDBCPreparedStatement
preparedStatement
,
DBSTypedObject
columnType
,
int
paramIndex
)
throws
DBCException
;
@Override
public
void
resetContents
()
{
// do nothing
}
@Override
public
String
toString
()
{
String
displayString
=
getDisplayString
(
DBDDisplayFormat
.
UI
);
return
displayString
==
null
?
DBConstants
.
NULL_VALUE_LABEL
:
displayString
;
}
}
\ No newline at end of file
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentChars.java
浏览文件 @
9edf59b0
...
...
@@ -44,7 +44,7 @@ import java.sql.SQLException;
public
class
JDBCContentChars
extends
JDBCContentAbstract
implements
DBDContentStorage
,
DBDContentCached
{
private
String
originalData
;
pr
ivate
String
data
;
pr
otected
String
data
;
public
JDBCContentChars
(
DBPDataSource
dataSource
,
String
data
)
{
super
(
dataSource
);
...
...
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/impl/jdbc/data/JDBCContentXML.java
浏览文件 @
9edf59b0
...
...
@@ -144,7 +144,7 @@ public class JDBCContentXML extends JDBCContentLOB {
}
else
if
(
xml
!=
null
)
{
preparedStatement
.
setSQLXML
(
paramIndex
,
xml
);
}
else
{
preparedStatement
.
setNull
(
paramIndex
+
1
,
java
.
sql
.
Types
.
SQLXML
);
preparedStatement
.
setNull
(
paramIndex
,
java
.
sql
.
Types
.
SQLXML
);
}
}
catch
(
SQLException
e
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录