Skip to content

Commit 438edc6

Browse files
Scorpio777888Gemini147258davidzollo
authored
[Doc][Improve] support chinese [docs/zh/connector-v2/sink/SqlServer.md] (#8851)
Co-authored-by: Gemini147258 <[email protected]> Co-authored-by: David Zollo <[email protected]>
1 parent 2dd2483 commit 438edc6

File tree

1 file changed

+176
-0
lines changed

1 file changed

+176
-0
lines changed

Diff for: docs/zh/connector-v2/sink/SqlServer.md

+176
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,176 @@
1+
# SQLServer
2+
3+
> JDBC SQLServer Sink 连接器
4+
5+
## 支持的 SQL Server 版本
6+
7+
- server:2008(或更高版本,仅供参考)
8+
9+
## 支持的引擎
10+
11+
> Spark<br/>
12+
> Flink<br/>
13+
> SeaTunnel Zeta<br/>
14+
15+
## 描述
16+
17+
通过 JDBC 写入数据。支持批处理和流处理模式,支持并发写入,支持精确一次语义(使用 XA 事务保证)。
18+
19+
## 使用依赖
20+
21+
### 对于 Spark/Flink 引擎
22+
23+
> 1. 需要确保 [jdbc 驱动 jar 包](https://mvnrepository.com/artifact/com.microsoft.sqlserver/mssql-jdbc) 已放置在目录 `${SEATUNNEL_HOME}/plugins/` 中。
24+
25+
### 对于 SeaTunnel Zeta 引擎
26+
27+
> 1. 需要确保 [jdbc 驱动 jar 包](https://mvnrepository.com/artifact/com.microsoft.sqlserver/mssql-jdbc) 已放置在目录 `${SEATUNNEL_HOME}/lib/` 中。
28+
29+
## 主要特性
30+
31+
- [x] [精确一次](../../concept/connector-v2-features.md)
32+
- [x] [cdc](../../concept/connector-v2-features.md)
33+
34+
> 使用 `Xa 事务` 来保证 `精确一次`。因此仅支持支持 `Xa 事务` 的数据库。可以通过设置 `is_exactly_once=true` 来启用。
35+
36+
## 支持的数据源信息
37+
38+
| 数据源 | 支持的版本 | 驱动类名 | URL 格式 | Maven 依赖 |
39+
|-----------|--------------------------|-----------------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------|
40+
| SQL Server | 支持版本 >= 2008 | com.microsoft.sqlserver.jdbc.SQLServerDriver | jdbc:sqlserver://localhost:1433 | [下载](https://mvnrepository.com/artifact/com.microsoft.sqlserver/mssql-jdbc) |
41+
42+
## 数据库依赖
43+
44+
> 请下载支持列表中对应的 'Maven' 依赖,并将其复制到 `$SEATUNNEL_HOME/plugins/jdbc/lib/` 工作目录中。<br/>
45+
> 例如 SQL Server 数据源:`cp mssql-jdbc-xxx.jar $SEATUNNEL_HOME/plugins/jdbc/lib/`
46+
47+
## 数据类型映射
48+
49+
| SQL Server 数据类型 | SeaTunnel 数据类型 |
50+
|-----------------------------------------|------------------------------------------------------------------------------------------------------|
51+
| BIT | BOOLEAN |
52+
| TINYINT<br/>SMALLINT | SHORT |
53+
| INTEGER | INT |
54+
| BIGINT | LONG |
55+
| DECIMAL<br />NUMERIC<br />MONEY<br />SMALLMONEY | DECIMAL((获取指定列的列大小)+1,<br/>(获取指定列的小数点右侧的位数))) |
56+
| REAL | FLOAT |
57+
| FLOAT | DOUBLE |
58+
| CHAR<br />NCHAR<br />VARCHAR<br />NTEXT<br />NVARCHAR<br />TEXT | STRING |
59+
| DATE | LOCAL_DATE |
60+
| TIME | LOCAL_TIME |
61+
| DATETIME<br />DATETIME2<br />SMALLDATETIME<br />DATETIMEOFFSET | LOCAL_DATE_TIME |
62+
| TIMESTAMP<br />BINARY<br />VARBINARY<br />IMAGE<br />UNKNOWN | 尚未支持 |
63+
64+
## 接收器选项
65+
66+
| 名称 | 类型 | 是否必填 | 默认值 | 描述 |
67+
|-----------------------------------|---------|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
68+
| url | String || - | JDBC 连接的 URL。参考示例:`jdbc:sqlserver://localhost:1433;databaseName=mydatabase` |
69+
| driver | String || - | 用于连接远程数据源的 JDBC 类名,如果使用 SQL Server,值为 `com.microsoft.sqlserver.jdbc.SQLServerDriver`|
70+
| user | String || - | 连接实例的用户名 |
71+
| password | String || - | 连接实例的密码 |
72+
| query | String || - | 使用此 SQL 将上游输入数据写入数据库。例如 `INSERT ...``query` 优先级更高。 |
73+
| database | String || - | 使用此 `database``table-name` 自动生成 SQL 并接收上游输入数据写入数据库。此选项与 `query` 互斥,且优先级更高。 |
74+
| table | String || - | 使用 `database` 和此 `table-name` 自动生成 SQL 并接收上游输入数据写入数据库。此选项与 `query` 互斥,且优先级更高。 |
75+
| primary_keys | Array || - | 此选项用于在自动生成 SQL 时支持 `insert``delete``update` 等操作。 |
76+
| support_upsert_by_query_primary_key_exist | Boolean || false | 选择使用 INSERT SQL、UPDATE SQL 来处理更新事件(INSERT, UPDATE_AFTER),基于查询主键是否存在。此配置仅在数据库不支持 upsert 语法时使用。**注意**:此方法性能较低。 |
77+
| connection_check_timeout_sec | Int || 30 | 用于验证连接完成的数据库操作的等待时间(秒)。 |
78+
| max_retries | Int || 0 | 提交失败(executeBatch)的重试次数。 |
79+
| batch_size | Int || 1000 | 对于批量写入,当缓冲的记录数达到 `batch_size` 或时间达到 `checkpoint.interval` 时,数据将被刷新到数据库中。 |
80+
| is_exactly_once | Boolean || false | 是否启用精确一次语义,将使用 Xa 事务。如果启用,需要设置 `xa_data_source_class_name`|
81+
| generate_sink_sql | Boolean || false | 根据要写入的数据库表生成 SQL 语句。 |
82+
| xa_data_source_class_name | String || - | 数据库驱动的 XA 数据源类名,例如 SQL Server 为 `com.microsoft.sqlserver.jdbc.SQLServerXADataSource`,其他数据源请参考附录。 |
83+
| max_commit_attempts | Int || 3 | 事务提交失败的重试次数。 |
84+
| transaction_timeout_sec | Int || -1 | 事务打开后的超时时间,默认为 -1(永不超时)。注意:设置超时可能会影响精确一次语义。 |
85+
| auto_commit | Boolean || true | 默认启用自动事务提交。 |
86+
| common-options | || - | 接收器插件通用参数,详情请参考 [Sink Common Options](../sink-common-options.md)|
87+
| enable_upsert | Boolean || true | 通过主键存在启用 upsert。如果任务中没有键重复数据,将此参数设置为 `false` 可以加快数据导入速度。 |
88+
89+
## 提示
90+
91+
> 如果未设置 `partition_column`,将以单并发运行;如果设置了 `partition_column`,将根据任务的并发度并行执行。
92+
93+
## 任务示例
94+
95+
### 简单示例:
96+
97+
> 这是一个读取 SQL Server 数据并直接插入到另一个表的示例
98+
99+
```
100+
env {
101+
# 可以在此设置引擎配置
102+
parallelism = 10
103+
}
104+
105+
source {
106+
# 这是一个示例源插件,**仅用于测试和演示功能**
107+
Jdbc {
108+
driver = com.microsoft.sqlserver.jdbc.SQLServerDriver
109+
url = "jdbc:sqlserver://localhost:1433;databaseName=column_type_test"
110+
user = SA
111+
password = "Y.sa123456"
112+
query = "select * from column_type_test.dbo.full_types_jdbc"
113+
# 并行分片读取字段
114+
partition_column = "id"
115+
# 分片数量
116+
partition_num = 10
117+
}
118+
# 如果想了解更多关于如何配置 SeaTunnel 的信息,并查看完整的源插件列表,
119+
# 请访问 https://seatunnel.apache.org/docs/connector-v2/source/Jdbc
120+
}
121+
122+
transform {
123+
# 如果想了解更多关于如何配置 SeaTunnel 的信息,并查看完整的转换插件列表,
124+
# 请访问 https://seatunnel.apache.org/docs/transform-v2/sql
125+
}
126+
127+
sink {
128+
Jdbc {
129+
driver = com.microsoft.sqlserver.jdbc.SQLServerDriver
130+
url = "jdbc:sqlserver://localhost:1433;databaseName=column_type_test"
131+
user = SA
132+
password = "Y.sa123456"
133+
query = "insert into full_types_jdbc_sink( id, val_char, val_varchar, val_text, val_nchar, val_nvarchar, val_ntext, val_decimal, val_numeric, val_float, val_real, val_smallmoney, val_money, val_bit, val_tinyint, val_smallint, val_int, val_bigint, val_date, val_time, val_datetime2, val_datetime, val_smalldatetime ) values( ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? )"
134+
}
135+
# 如果想了解更多关于如何配置 SeaTunnel 的信息,并查看完整的接收器插件列表,
136+
# 请访问 https://seatunnel.apache.org/docs/connector-v2/sink/Jdbc
137+
}
138+
```
139+
140+
### CDC(变更数据捕获)事件
141+
142+
> 我们也支持 CDC 变更数据。在这种情况下,需要配置 `database``table``primary_keys`
143+
144+
```
145+
Jdbc {
146+
plugin_input = "customers"
147+
driver = com.microsoft.sqlserver.jdbc.SQLServerDriver
148+
url = "jdbc:sqlserver://localhost:1433;databaseName=column_type_test"
149+
user = SA
150+
password = "Y.sa123456"
151+
generate_sink_sql = true
152+
database = "column_type_test"
153+
table = "dbo.full_types_sink"
154+
batch_size = 100
155+
primary_keys = ["id"]
156+
}
157+
```
158+
159+
### 精确一次接收器
160+
161+
> 事务性写入可能较慢,但数据更准确
162+
163+
```
164+
Jdbc {
165+
driver = com.microsoft.sqlserver.jdbc.SQLServerDriver
166+
url = "jdbc:sqlserver://localhost:1433;databaseName=column_type_test"
167+
user = SA
168+
password = "Y.sa123456"
169+
query = "insert into full_types_jdbc_sink( id, val_char, val_varchar, val_text, val_nchar, val_nvarchar, val_ntext, val_decimal, val_numeric, val_float, val_real, val_smallmoney, val_money, val_bit, val_tinyint, val_smallint, val_int, val_bigint, val_date, val_time, val_datetime2, val_datetime, val_smalldatetime ) values( ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? )"
170+
is_exactly_once = "true"
171+
xa_data_source_class_name = "com.microsoft.sqlserver.jdbc.SQLServerXADataSource"
172+
}
173+
174+
# 如果想了解更多关于如何配置 SeaTunnel 的信息,并查看完整的接收器插件列表,
175+
# 请访问 https://seatunnel.apache.org/docs/connector-v2/sink/Jdbc
176+
```

0 commit comments

Comments
 (0)