Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
95fd9327
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,发现更多精彩内容 >>
提交
95fd9327
编写于
1月 08, 2017
作者:
S
Serge Rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#1127 MySQL zero date/timestamp binding
上级
60684c70
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
74 addition
and
0 deletion
+74
-0
plugins/org.jkiss.dbeaver.ext.mysql/src/org/jkiss/dbeaver/ext/mysql/data/MySQLDateTimeValueHandler.java
...iss/dbeaver/ext/mysql/data/MySQLDateTimeValueHandler.java
+74
-0
未找到文件。
plugins/org.jkiss.dbeaver.ext.mysql/src/org/jkiss/dbeaver/ext/mysql/data/MySQLDateTimeValueHandler.java
浏览文件 @
95fd9327
...
...
@@ -17,17 +17,91 @@
*/
package
org.jkiss.dbeaver.ext.mysql.data
;
import
org.jkiss.code.NotNull
;
import
org.jkiss.code.Nullable
;
import
org.jkiss.dbeaver.model.data.DBDDataFormatterProfile
;
import
org.jkiss.dbeaver.model.data.DBDDisplayFormat
;
import
org.jkiss.dbeaver.model.exec.DBCException
;
import
org.jkiss.dbeaver.model.exec.DBCResultSet
;
import
org.jkiss.dbeaver.model.exec.DBCSession
;
import
org.jkiss.dbeaver.model.exec.DBCStatement
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement
;
import
org.jkiss.dbeaver.model.impl.jdbc.data.handlers.JDBCDateTimeValueHandler
;
import
org.jkiss.dbeaver.model.messages.ModelMessages
;
import
org.jkiss.dbeaver.model.struct.DBSTypedObject
;
import
java.sql.SQLException
;
import
java.sql.Types
;
import
java.util.Date
;
/**
* MySQL datetime handler
*/
public
class
MySQLDateTimeValueHandler
extends
JDBCDateTimeValueHandler
{
private
static
final
Date
ZERO_DATE
=
new
Date
(
0
l
);
private
static
final
Date
ZERO_TIMESTAMP
=
new
Date
(
0
l
);
private
static
final
String
ZERO_DATE_STRING
=
"0000-00-00"
;
private
static
final
String
ZERO_TIMESTAMP_STRING
=
"0000-00-00 00:00:00"
;
public
MySQLDateTimeValueHandler
(
DBDDataFormatterProfile
formatterProfile
)
{
super
(
formatterProfile
);
}
@Override
public
Object
fetchValueObject
(
@NotNull
DBCSession
session
,
@NotNull
DBCResultSet
resultSet
,
@NotNull
DBSTypedObject
type
,
int
index
)
throws
DBCException
{
return
super
.
fetchValueObject
(
session
,
resultSet
,
type
,
index
);
}
@Override
public
void
bindValueObject
(
@NotNull
DBCSession
session
,
@NotNull
DBCStatement
statement
,
@NotNull
DBSTypedObject
type
,
int
index
,
@Nullable
Object
value
)
throws
DBCException
{
if
(
value
==
ZERO_DATE
||
value
==
ZERO_TIMESTAMP
)
{
// Workaround for zero values (#1127)
try
{
JDBCPreparedStatement
dbStat
=
(
JDBCPreparedStatement
)
statement
;
if
(
value
==
ZERO_DATE
)
{
dbStat
.
setString
(
index
+
1
,
ZERO_DATE_STRING
);
}
else
{
dbStat
.
setString
(
index
+
1
,
ZERO_TIMESTAMP_STRING
);
}
}
catch
(
SQLException
e
)
{
throw
new
DBCException
(
ModelMessages
.
model_jdbc_exception_could_not_bind_statement_parameter
,
e
);
}
}
else
{
super
.
bindValueObject
(
session
,
statement
,
type
,
index
,
value
);
}
}
@NotNull
@Override
public
String
getValueDisplayString
(
@NotNull
DBSTypedObject
column
,
Object
value
,
@NotNull
DBDDisplayFormat
format
)
{
if
(
value
==
ZERO_DATE
)
{
return
ZERO_DATE_STRING
;
}
else
if
(
value
==
ZERO_TIMESTAMP
)
{
return
ZERO_TIMESTAMP_STRING
;
}
return
super
.
getValueDisplayString
(
column
,
value
,
format
);
}
@Override
public
Object
getValueFromObject
(
@NotNull
DBCSession
session
,
@NotNull
DBSTypedObject
type
,
Object
object
,
boolean
copy
)
throws
DBCException
{
if
(
object
instanceof
String
)
{
switch
(
type
.
getTypeID
())
{
case
Types
.
DATE
:
if
(
object
.
equals
(
ZERO_DATE_STRING
))
{
return
ZERO_DATE
;
}
break
;
default
:
if
(
object
.
equals
(
ZERO_TIMESTAMP_STRING
))
{
return
ZERO_TIMESTAMP
;
}
break
;
}
}
return
super
.
getValueFromObject
(
session
,
type
,
object
,
copy
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录