я пытаюсь достичь
{
"source": "NEWS",
"metadata": {
"publishTime": "02/06/2019 09:56:24.317",
"channel": "paper",
"status":"active"
},
"Data": {
"NAME": 67,
"GENDER": "MALE",
...
}
}
но я застрял с этим
{
"Data": {
"NAME": 67,
"GENDER": "MALE",
...
},
"source": "NEWS",
"metadata": "{\"channel\":'paper'}"
}
и ниже мои разъемы. Свойства
name=source-sqlserver-user
connector.class=io.confluent.connect.jdbc.JdbcSourceConnector
tasks.max=1
connection.url=jdbc:sqlserver://localhost:1433;database=testing;username=xyz;password=xyz;
table.whitelist=Tickets
mode=incrementing
incrementing.column.name=Ticket_id
validate.non.null=false
topic.prefix=my-mssql-
transforms=MakeMap123,value,extract,InsertSourceDetails,xyz
transforms.MakeMap123.type=org.apache.kafka.connect.transforms.HoistField$Value
transforms.MakeMap123.field=Data
transforms.value.type=org.apache.kafka.connect.transforms.ValueToKey
transforms.value.fields=Ticket_id
transforms.extract.type=org.apache.kafka.connect.transforms.ExtractField$Value
transforms.extract.field=Ticket_id
#transforms.InsertTopic.type=org.apache.kafka.connect.transforms.InsertField$Value
#transforms.InsertTopic.topic.field=messagetopic
eetransforms.InsertSourceDetails.type=org.apache.kafka.connect.transforms.InsertField$Value
transforms.InsertSourceDetails.static.field=source
transforms.InsertSourceDetails.static.value=NEWS
transforms.xyz.type=org.apache.kafka.connect.transforms.InsertField$Value
transforms.xyz.static.field=metadata
transforms.xyz.static.value={"channel":'paper'}
В этом источнике: NEWS является статическим полем и работает как исключение, но есть ли возможность, что мы извлечем несколько столбцов одной таблицы (все столбцы принадлежат одной таблице) и поместим его в качестве другого ключа json (метаданные в моем случае) как показано выше. и да, я пытался ValueToKey
и ExtractField$Value
, но ValueToKey выбрасывает NPE
Можно ли этого добиться с помощью kafka connect Transformation? или я что-то упустил ??
или я должен использовать пользовательскую схему авро? Любые примеры для пользовательских схем AVRO высоко ценится.