使用 DIH (DataImportHandler) 的动态列名 [英] Dynamic column names using DIH (DataImportHandler)

查看:21
本文介绍了使用 DIH (DataImportHandler) 的动态列名的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

有没有办法使用返回的值创建动态列(作为键/值)名称从查询中抛出 DIH (DataImportHandler)?

Is there a way to create dynamic column (as a key/value) names using the values returned from the query throw DIH (DataImportHandler)?

例如:

<entity name="foo" dataSource="my_database" query="select key,value from foo where id=${item.id}">
   <field column="${foo.key}" value="${foo.value}" name="${foo.key}_s"/>
</entity>

??

推荐答案

使用 ScriptTransformer -

示例 -

数据配置 - 添加自定义字段 -

Data Config - Add custom field -

<script><![CDATA[
        function addfield(row){
            var fieldName = row.get('key') + "_s"
            row.put(fieldName, row.get('value'));
            return row;
        }
]]></script>

实体映射 -

<entity name="foo" dataSource="my_database" transformer="script:addfield" query="select key,value from foo where id=${item.id}">
    ......
</entity>

这篇关于使用 DIH (DataImportHandler) 的动态列名的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆