Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
bc78206d
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,发现更多精彩内容 >>
提交
bc78206d
编写于
10月 28, 2020
作者:
A
Anastasiya Volkova
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#1233 "Replace into" insert keyword to export options added
Former-commit-id:
ecb4781b
上级
378cdd5a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
24 addition
and
15 deletion
+24
-15
plugins/org.jkiss.dbeaver.data.transfer/plugin.xml
plugins/org.jkiss.dbeaver.data.transfer/plugin.xml
+1
-1
plugins/org.jkiss.dbeaver.data.transfer/src/org/jkiss/dbeaver/tools/transfer/stream/exporter/DataExporterSQL.java
...eaver/tools/transfer/stream/exporter/DataExporterSQL.java
+23
-14
未找到文件。
plugins/org.jkiss.dbeaver.data.transfer/plugin.xml
浏览文件 @
bc78206d
...
...
@@ -172,7 +172,7 @@
<propertyGroup
label=
"%dataTransfer.processor.sql.propertyGroup.formatting.label"
>
<property
id=
"lineBeforeRows"
label=
"%dataTransfer.processor.sql.property.lineBeforeRows.name"
type=
"boolean"
description=
"%dataTransfer.processor.sql.property.lineBeforeRows.description"
defaultValue=
"true"
/>
<property
id=
"keywordCase"
label=
"%dataTransfer.processor.sql.property.keywordCase.name"
type=
"string"
description=
"%dataTransfer.processor.sql.property.keywordCase.description"
defaultValue=
"upper"
required=
"true"
validValues=
"upper,lower"
/>
<property
id=
"upsertKeyword"
label=
"%dataTransfer.processor.sql.property.upsertKeyword.name"
type=
"string"
description=
"%dataTransfer.processor.sql.property.upsertKeyword.description"
defaultValue=
"INSERT"
required=
"true"
validValues=
"INSERT,UPDATE OR,UPSERT INTO,ON DUPLICATE KEY UPDATE,ON CONFLICT"
/>
<property
id=
"upsertKeyword"
label=
"%dataTransfer.processor.sql.property.upsertKeyword.name"
type=
"string"
description=
"%dataTransfer.processor.sql.property.upsertKeyword.description"
defaultValue=
"INSERT"
required=
"true"
validValues=
"INSERT,UPDATE OR,UPSERT INTO,
REPLACE INTO,
ON DUPLICATE KEY UPDATE,ON CONFLICT"
/>
<property
id=
"insertOnConflict"
label=
"%dataTransfer.processor.sql.property.insertOnConflict.name"
type=
"string"
description=
"%dataTransfer.processor.sql.property.insertOnConflict.description"
defaultValue=
""
required=
"true"
/>
</propertyGroup>
</processor>
...
...
plugins/org.jkiss.dbeaver.data.transfer/src/org/jkiss/dbeaver/tools/transfer/stream/exporter/DataExporterSQL.java
浏览文件 @
bc78206d
...
...
@@ -73,7 +73,8 @@ public class DataExporterSQL extends StreamExporterAbstract {
private
final
String
KEYWORD_INSERT_ALL
=
"INSERT ALL"
;
private
final
String
KEYWORD_SELECT_FROM_DUAL
=
"SELECT 1 FROM DUAL"
;
private
final
static
String
KEYWORD_UPDATE_OR
=
"UPDATE OR"
;
private
final
static
String
KEYWORD_UPSERT
=
"UPSERT INTO"
;
private
final
static
String
KEYWORD_UPSERT_INTO
=
"UPSERT INTO"
;
private
final
static
String
KEYWORD_REPLACE_INTO
=
"REPLACE INTO"
;
private
final
static
String
KEYWORD_DUPLICATE_KEY
=
"ON DUPLICATE KEY UPDATE"
;
private
final
static
String
KEYWORD_ON_CONFLICT
=
"ON CONFLICT"
;
...
...
@@ -87,7 +88,8 @@ public class DataExporterSQL extends StreamExporterAbstract {
enum
InsertKeyword
{
INSERT
(
"INSERT"
),
UPDATE
(
KEYWORD_UPDATE_OR
),
UPSERT
(
KEYWORD_UPSERT
),
UPSERT
(
KEYWORD_UPSERT_INTO
),
REPLACE
(
KEYWORD_REPLACE_INTO
),
ON_DUPLICATE
(
KEYWORD_DUPLICATE_KEY
),
ON_CONFLICT
(
KEYWORD_ON_CONFLICT
);
private
String
value
;
...
...
@@ -196,18 +198,25 @@ public class DataExporterSQL extends StreamExporterAbstract {
sqlBuffer
.
append
(
rowDelimiter
);
}
}
if
(
insertKeyword
==
InsertKeyword
.
UPDATE
)
{
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_UPDATE_OR
)).
append
(
" "
);
}
if
(
insertKeyword
==
InsertKeyword
.
UPSERT
)
{
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_UPSERT
));
}
else
if
(
insertMode
==
SQLDialect
.
MultiValueInsertMode
.
INSERT_ALL
)
{
if
(
rowCount
%
rowsInStatement
==
0
)
{
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_INSERT_ALL
)).
append
(
"\n"
);
}
sqlBuffer
.
append
(
"\t"
).
append
(
identifierCase
.
transform
(
KEYWORD_INTO
));
}
else
{
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_INSERT_INTO
));
switch
(
insertKeyword
)
{
case
UPDATE:
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_UPDATE_OR
)).
append
(
" "
).
append
(
identifierCase
.
transform
(
KEYWORD_INSERT_INTO
));
break
;
case
UPSERT:
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_UPSERT_INTO
));
break
;
case
REPLACE:
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_REPLACE_INTO
));
break
;
default
:
if
(
insertMode
==
SQLDialect
.
MultiValueInsertMode
.
INSERT_ALL
)
{
if
(
rowCount
%
rowsInStatement
==
0
)
{
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_INSERT_ALL
)).
append
(
"\n"
);
}
sqlBuffer
.
append
(
"\t"
).
append
(
identifierCase
.
transform
(
KEYWORD_INTO
));
}
else
{
sqlBuffer
.
append
(
identifierCase
.
transform
(
KEYWORD_INSERT_INTO
));
}
}
sqlBuffer
.
append
(
" "
).
append
(
tableName
).
append
(
" ("
);
boolean
hasColumn
=
false
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录